body{font-family:Arial,Helvetica,sans-serif}.login-page{height:100vh;background:linear-gradient(180deg,#fff,#015f2b);display:flex;align-items:center;justify-content:center;color:#fff}.login-card{width:360px;background:#d6d4d4f2;padding:40px 32px;border-radius:14px;text-align:center;box-shadow:0 0 40px #00ff8014;color:#000}.login-logo img{width:80px;margin-bottom:16px}.login-title{font-weight:700;margin:0}.login-title-text{display:inline-block}.form-group{text-align:left;margin-bottom:16px}.form-group label{font-size:13px;color:#000;font-weight:700}.form-group input{width:100%;padding:10px;margin-top:6px;border-radius:4px;border:none;outline:none;background:#f5f5f5;font-size:14px;box-sizing:border-box}.password-wrapper input{padding-right:45px}.toggle-password{position:absolute;right:12px;top:60%;transform:translateY(-50%) translateY(8px)}.toggle-password img{width:18px;height:18px;cursor:pointer;opacity:.8}.toggle-password img:hover{opacity:1}.login-links{text-align:right;font-size:12px;margin-bottom:20px}.login-links .forgot{color:#02643d;cursor:pointer;font-weight:700}.forgot{text-decoration:underline}.login-btn{width:100%;padding:12px;border:none;border-radius:20px;background:#04bd73;color:#000;font-weight:800;cursor:pointer;transition:.2s}.login-btn:hover{background:#00e68a}.login-btn:disabled{opacity:.6;cursor:not-allowed}.error-text{color:#ff5c5c;font-size:13px;margin-bottom:10px}.register-text{margin-top:18px;font-size:13px;color:#000;font-weight:700}.register-link:visited,.register-link:hover{color:#02643d}.register-text span{color:#0f9;cursor:pointer;text-decoration:underline}.success-message{color:green;font-weight:700;text-align:center;margin-bottom:10px}.error-text{color:red;text-align:center;margin-bottom:10px}.password-wrapper{position:relative}.login-title-wrapper{display:flex;align-items:center;justify-content:flex-start;gap:10px;margin-bottom:28px;width:100%;border-bottom:2px solid #141414;padding-bottom:10px;text-align:left}.login-gear{width:23px;height:23px;margin-left:10px;transform:none;align-self:center}@media(max-width:768px){.login-page{padding:20px}.login-card{width:90%;padding:30px 20px;border-radius:12px;color:000}.login-logo img{width:65px}.login-title{font-size:18px}.form-group input{font-size:13px;padding:9px}.toggle-password{top:32px;right:10px;transform:translateY(-50%) translateY(10px)}.login-btn{padding:11px;font-size:14px}.register-text{font-size:12px}.login-links{font-size:11px}.toggle-password img{width:16px;height:16px}}body{margin:0;padding:0}.register-page{position:relative;height:100vh;width:100%;background-image:url(/assets/background-_Smm77eA.png);background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;flex-direction:column}.register-page:before{content:"";position:absolute;inset:0;background-image:url(/assets/background-_Smm77eA.png);background-size:cover;background-position:center;background-repeat:no-repeat;opacity:.4;z-index:-1}.register-card{width:min(420px,90%);margin:auto;background:#d9d9d9;padding:25px;border-radius:10px;box-shadow:0 4px 10px #00000040}.register-header{background:#111;color:#fff;display:flex;align-items:center;padding:15px 40px;gap:15px}.register-logo{width:45px;height:45px}.register-header h1{font-size:22px;font-weight:700}.register-card{width:400px;margin:auto;background:#d9d9d9;padding:25px;border-radius:6px;box-shadow:0 4px 10px #00000040}.register-card h2{text-align:center;margin-bottom:20px;font-size:16px;font-weight:700}.register-card form{display:flex;flex-direction:column}.register-card label{font-size:12px;font-weight:700;margin-top:10px}.register-card input,.register-card select{padding:7px;border:none;border-radius:3px;margin-top:3px;font-size:12px}.row{display:flex;gap:10px;margin-top:10px}.row div{flex:1}.register-btn{margin-top:20px;background:#00b050;color:#fff;padding:10px;border:none;border-radius:4px;font-weight:700;cursor:pointer;width:120px;align-self:flex-end}.register-btn:hover{background:#009140}.message{margin-top:10px;font-size:13px;font-weight:700;text-align:center}@media(max-width:768px){.register-card{width:80%;padding:20px}.row{flex-direction:row;gap:10px}.register-btn{width:100%;align-self:center}}:root{--primary-bg: #1a1b23;--secondary-bg: #f4f6f8;--text-color: #333333;--text-light: #ffffff;--accent-color: #00b050;--sidebar-width: 260px;--header-height: 70px}*{box-sizing:border-box;margin:0;padding:0;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}body{overflow-y:auto}.app-layout{display:flex;min-height:100vh;width:100%}.sidebar{width:var(--sidebar-width);background-color:var(--primary-bg);color:var(--text-light);display:flex;flex-direction:column;flex-shrink:0;transition:transform .3s ease;z-index:100;border-right:1px solid #2e2e2e}.menu-list{flex:1;overflow-y:auto;padding-top:20px}.menu-item{display:flex;justify-content:space-between;align-items:center;padding:15px 25px;color:#b0b0b0;text-decoration:none;font-size:15px;font-weight:500;transition:all .2s ease}.menu-item:hover{color:#fff;background-color:#ffffff0d}.menu-item.active{background-color:#2a2b36;color:var(--text-light);border-left:4px solid var(--accent-color);padding-left:21px}.arrow{font-size:1.2rem;opacity:.5}.menu-item:hover .arrow,.menu-item.active .arrow{opacity:1}.menu-divider{border:0;height:1px;background-color:#444;margin:10px 20px;opacity:.5}.sidebar-footer{padding:20px;border-top:1px solid #2e2e2e;display:flex;align-items:center;justify-content:flex-start;gap:15px}.settings-icon{font-size:1.5rem;text-decoration:none;color:#fff;transition:transform .3s ease}.settings-icon:hover{transform:rotate(90deg);color:#d1d1d1}.main-content-wrapper{flex:1;display:flex;flex-direction:column;position:relative}.header{height:var(--header-height);background-color:#fff;display:flex;align-items:center;padding:0 30px;box-shadow:0 2px 5px #0000000d;z-index:90}.hamburger-btn{display:none;background:none;border:none;font-size:1.8rem;cursor:pointer;color:#333;margin-right:15px}.header-title{font-size:1.5rem;font-weight:600;color:var(--primary-bg)}.main-content{flex:1;padding:30px;overflow:visible;min-height:calc(100vh - var(--header-height));background-image:url(/assets/background-_Smm77eA.png);background-size:cover;background-position:center;background-repeat:no-repeat}.mobile-overlay{display:none}@media(max-width:768px){.hamburger-btn{display:block}.sidebar{position:fixed;top:0;left:0;height:100%;width:260px;transform:translate(-100%);transition:transform .3s ease-in-out;box-shadow:2px 0 10px #0003}.sidebar.open{transform:translate(0)}.mobile-overlay{display:block;position:fixed;top:0;left:0;width:100vw;height:100vh;background-color:#00000080;z-index:95;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.header{padding:0 15px}.header-title{font-size:1.2rem}.main-content{padding:15px}}.management-container{display:flex;gap:20px;height:calc(100vh - 100px);min-height:500px;padding-bottom:20px;box-sizing:border-box}.management-card{flex:1;min-width:350px;background-color:#e6e6e6;border-radius:14px;box-shadow:0 6px 14px #0009;border:1px solid #e1e4ea;color:#333;display:flex;flex-direction:column;height:100%;overflow-y:auto;position:relative;padding:0}.management-card::-webkit-scrollbar{width:8px}.management-card::-webkit-scrollbar-track{background:transparent}.management-card::-webkit-scrollbar-thumb{background-color:#ccc;border-radius:4px}.management-card h3{position:sticky;top:0;z-index:10;background-color:#e6e6e6;margin:0;padding:20px 25px;text-align:center;color:#1a1b23;font-size:1.15rem;font-weight:700;letter-spacing:.3px;border-bottom:1px solid #d1d1d1}.data-table{width:100%;border-collapse:separate;border-spacing:0;padding:0 15px 20px}.data-table th{position:sticky;top:63px;z-index:5;background-color:#e6e6e6;text-align:left;font-weight:700;padding:10px;font-size:1.1rem;color:#1a1b23;box-shadow:0 2px 5px #0000000d}.data-table th:last-child{text-align:right;padding-right:90px}.data-table td{padding:12px 10px;vertical-align:middle;font-weight:500;color:#444;border-bottom:1px solid #dcdcdc}.data-table td:last-child{text-align:right}.status-badge{display:inline-flex;align-items:center;gap:6px;font-weight:700;padding:6px 10px;border-radius:20px;font-size:.9rem}.status-active{background:#baf7d6;color:#0a7a3a}.status-inactive{background:#faa9a9;color:#c92a2a}.action-btn{padding:8px 14px;border:none;border-radius:6px;font-size:.8rem;font-weight:700;cursor:pointer;margin-right:8px;color:#fff;transition:opacity .2s,transform .1s;box-shadow:0 2px 4px #0003}.action-btn:hover{opacity:.9;transform:translateY(-1px)}.action-btn:active{transform:translateY(0)}.btn-approve,.btn-activate{background-color:#00b050}.btn-reject,.btn-delete{background-color:#dc3545}.btn-deactivate{background-color:#f0ad4e;color:#fff}@media(max-width:900px){.management-container{flex-direction:column;height:auto;gap:30px}.management-card{height:auto;max-height:500px;overflow-y:auto;width:100%;min-width:auto}.data-table th{top:60px}.data-table th:last-child{padding-right:10px}}html,body,#root{overflow-y:auto;overflow-x:hidden;height:auto;min-height:100%}body{margin:0;background:#eef2f5;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.curriculum-container{width:100%;height:auto;min-height:100%;padding:40px 20px;box-sizing:border-box;display:block;overflow:visible}.curriculum-content{background-color:#dcdcdc;width:100%;max-width:1100px;margin:0 auto;border-radius:8px;padding:25px;box-shadow:0 4px 15px #0000001a;box-sizing:border-box}.status-msg{text-align:center;color:#666;margin-top:20px}.error-msg{text-align:center;color:#d32f2f;margin-top:20px;font-weight:700}.semester-group{margin-bottom:35px;background-color:#dcdcdc;overflow-x:auto;overflow-y:hidden;padding-bottom:5px}.semester-group::-webkit-scrollbar{height:6px}.semester-group::-webkit-scrollbar-thumb{background-color:#bbb;border-radius:4px}.group-header{text-align:center;font-weight:800;font-size:1rem;padding:12px 0;border-top:3px solid white;border-bottom:3px solid white;margin-bottom:15px;text-transform:uppercase;color:#000;letter-spacing:.5px;min-width:700px}.curr-table-header,.curr-table-row{display:grid;grid-template-columns:1.2fr 3fr 1fr 1fr 1.5fr;align-items:center;padding:10px;min-width:700px}.curr-table-header{font-weight:700;font-size:.9rem;text-align:center;margin-bottom:5px}.curr-table-row{font-size:.95rem;text-align:center;color:#333;border-bottom:1px solid rgba(255,255,255,.5)}.col-code{text-align:left;padding-left:15px;font-weight:600}.col-title{text-align:left}.col-units,.col-hours{border-left:1px solid #aaa;border-right:1px solid #aaa}.col-units small,.col-hours small{font-size:.8em;color:#555}.col-actions{display:flex;justify-content:center;gap:10px}.btn-update{background-color:#ffb300;color:#000;border:none;padding:6px 15px;border-radius:4px;font-weight:700;font-size:.8rem;cursor:pointer}.btn-delete-sub{background-color:#d32f2f;color:#fff;border:none;padding:6px 15px;border-radius:4px;font-weight:700;font-size:.8rem;cursor:pointer}.add-btn-container{display:flex;justify-content:flex-end;margin-top:30px}.btn-add-subject{background-color:#00c853;color:#fff;border:none;padding:12px 25px;border-radius:5px;font-weight:700;font-size:1rem;cursor:pointer}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;padding:20px;z-index:9999}.modal-window{background:#fff;width:500px;max-width:100%;border-radius:8px;display:flex;flex-direction:column;max-height:90vh}.modal-body{padding:20px;overflow-y:auto}.modal-header{background-color:#222;color:#fff;padding:15px 20px;display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0}.close-btn{background:none;border:none;color:#fff;font-size:1.5rem;cursor:pointer}.form-row{display:flex;gap:15px;margin-bottom:15px}.flex-grow{flex:1}.form-group label{display:block;font-size:.9rem;font-weight:700;margin-bottom:5px;color:#333}.form-group input,.form-group select{width:100%;padding:8px;border:1px solid #ccc;border-radius:4px;box-sizing:border-box}.modal-footer{padding:15px 20px;background-color:#f1f1f1;display:flex;justify-content:flex-end;gap:10px}.btn-save{background:#00c853;color:#fff;border:none;padding:10px 20px;border-radius:4px;font-weight:700;cursor:pointer}.btn-cancel{background:#ddd;color:#333;border:none;padding:10px 20px;border-radius:4px;cursor:pointer}@media(max-width:768px){.curriculum-container{padding:15px;height:auto}.curriculum-content{padding:15px 10px}.modal-window{width:100%;max-height:95vh}.form-row{flex-direction:column;gap:12px}.btn-add-subject,.btn-save,.btn-cancel{width:100%;padding:14px}.modal-footer{flex-direction:column-reverse}}.room-mgmt-container{display:flex;width:100vw;height:100vh;overflow:hidden;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;position:relative}html,body{height:100%;margin:0;overflow:hidden}.main-content{padding:0!important;background:transparent!important;overflow:hidden}.room-sidebar{width:380px;background-color:#22262e;color:#fff;display:flex;flex-direction:column;padding:30px 20px;box-shadow:2px 0 10px #0000001a;z-index:10}.sidebar-title{text-align:center;font-size:1.8rem;font-weight:700;margin-bottom:30px;letter-spacing:.5px}.room-header-row{display:flex;justify-content:space-between;padding-bottom:15px;border-bottom:1px solid #444;margin-bottom:10px;font-size:1.1rem;font-weight:700}.col-name{width:30%;text-align:left;padding-left:10px}.col-type{width:40%;text-align:center}.col-action{width:30%;text-align:right;padding-right:5px}.room-list-scroll{flex:1;overflow-y:auto;padding-right:5px;padding-bottom:60px}.room-list-scroll::-webkit-scrollbar{width:6px}.room-list-scroll::-webkit-scrollbar-thumb{background-color:#555;border-radius:4px}.room-row{display:flex;justify-content:space-between;align-items:center;padding:15px 0;border-bottom:1px solid #333;font-size:1rem}.text-bold{font-weight:700}.text-gray{color:#aaa}.empty-state{text-align:center;color:#666;margin-top:20px}.btn-delete{background-color:#d32f2f;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-weight:600;font-size:.9rem;transition:background .2s}.btn-delete:hover{background-color:#b71c1c}.add-room-card{position:absolute;top:40%;left:calc(380px + (100% - 380px)/2);transform:translate(-50%,-50%);background-color:#cfcece;width:500px;padding:40px;border-radius:12px;box-shadow:0 4px 20px #00000014;max-height:85vh;overflow-y:auto}.card-title{margin-top:0;margin-bottom:25px;font-size:1.5rem;color:#333;font-weight:700}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:700;margin-bottom:8px;font-size:.95rem;color:#333}.form-group input,.form-group select{width:100%;padding:12px;border:1px solid #ddd;border-radius:6px;background-color:#fff;font-size:1rem;box-sizing:border-box}.form-group input:focus,.form-group select:focus{outline:2px solid #00c853;border-color:#00c853}.form-footer{display:flex;justify-content:flex-end;margin-top:20px}.btn-add{background-color:#00c853;color:#fff;border:none;padding:12px 40px;border-radius:6px;font-weight:700;font-size:1rem;cursor:pointer;transition:background .2s}.btn-add:hover{background-color:#009624}.room-mgmt-container:before{content:"";position:absolute;inset:0 0 0 380px;background-image:url(/assets/background-_Smm77eA.png);background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0}
