@import url(https://fonts.googleapis.com/css2?family=Kodchasan:ital,wght@0,200;0,300;0,400;0,500;0,600;0,700;1,200;1,300;1,400;1,500;1,600;1,700&display=swap);body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box;font-family:Kodchasan,sans-serif;margin:0;padding:0}#root,body,html{min-height:100%;width:100%}body{background-color:#fffbfe}.app-wrapper{display:flex;flex-direction:column;min-height:100vh}.app-wrapper main{flex:1 1}nav{align-items:center;background-color:#fffbfe;box-sizing:border-box;color:#fff;display:flex;justify-content:space-between;left:0;padding:20px 5%;position:fixed;top:0;width:100%;z-index:999}.navbar-logo{font-size:1.5rem;font-weight:700}.navbar-logo a{text-decoration:none}.navbar-logo-class{color:#ef5b5b}.navbar-logo-grid{color:#9984d4}.navbar-links{display:flex;gap:24px}.navbar-link{color:#475657;font-size:14px;font-weight:500;text-decoration:none;transition:color .2s ease}.navbar-link:hover{color:#ef5b5b}.navbar-devclub{color:#9984d4;font-weight:500;letter-spacing:1px}.navbar-devclub a{color:#ef5b5b;text-decoration:none}@media (max-width:768px){.navbar-links{display:none}}@media (max-width:420px){.navbar-logo{font-size:1.2rem}.navbar-devclub{font-size:.8rem}}@media (max-width:768px){nav{display:none!important}}.mobile-hamburger{align-items:center;background:#fffbfe;border:1px solid #d0d5dd;border-radius:12px;box-shadow:0 4px 12px #0000001a;color:#475657;cursor:pointer;display:flex;height:48px;justify-content:center;left:16px;position:fixed;top:16px;transition:all .2s ease;width:48px;z-index:1001}.mobile-hamburger:hover{background:#f5f5f5;border-color:#ef5b5b;color:#ef5b5b}.mobile-sidebar-overlay{animation:fadeIn .2s ease;background:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-sidebar{background:#fffbfe;box-shadow:4px 0 24px #00000026;display:flex;flex-direction:column;height:100vh;left:-280px;position:fixed;top:0;transition:left .3s ease;width:280px;z-index:1000}.mobile-sidebar.open{left:0}.mobile-sidebar-header{border-bottom:1px solid #e9ecef;padding:24px 20px}.mobile-sidebar-logo{display:block;font-size:1.8rem;font-weight:700;text-decoration:none}.mobile-sidebar-logo .logo-class{color:#ef5b5b}.mobile-sidebar-logo .logo-grid{color:#9984d4}.mobile-sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:4px;padding:16px 12px}.mobile-sidebar-link{align-items:center;border-radius:10px;color:#475657;display:flex;font-size:15px;font-weight:500;gap:12px;padding:14px 16px;text-decoration:none;transition:all .2s ease}.mobile-sidebar-link:hover{background:#f5f0fa;color:#9984d4}.mobile-sidebar-link.active{background:linear-gradient(135deg,#ef5b5b,#f77);color:#fff}.mobile-sidebar-link.active svg{stroke-width:2.5}.mobile-sidebar-footer{border-top:1px solid #e9ecef;padding:20px;text-align:center}.mobile-sidebar-footer p{color:#6b7c7d;font-size:13px;margin:0}.mobile-sidebar-footer a{color:#ef5b5b;font-weight:500;text-decoration:none}.mobile-sidebar-footer a:hover{text-decoration:underline}.footer{background:#fffbfe;border-top:1px solid #e9ecef;padding:16px 5%;text-align:center}.footer p{color:#6b7c7d;font-size:14px;margin:0}.footer .heart,.footer a{color:#ef5b5b}.footer a{font-weight:500;text-decoration:none}.footer a:hover{text-decoration:underline}.home{align-items:start;display:flex;justify-content:space-around;min-height:100vh;padding:100px 5%}.home-content,.home-hero{width:50%}.home-content{line-height:1.5;padding:3%}.home-content h2{font-family:Arial,Helvetica,sans-serif;font-size:2em}.home-content h2,.home-content p{color:#475657;margin-bottom:1em}.home-content p ul{margin-top:5px;padding-left:20px}.home-content p a{color:#9984d4}.home-content button{background-color:#ef5b5b;border:none;border-radius:5px;color:#fff;cursor:pointer;font-size:1em;margin-top:1em;padding:10px 20px;transition:.3s}.home-content button:hover{scale:1.02}.home-hero img{width:100%}@media (max-width:420px){.home{flex-direction:column}.home-content,.home-hero{width:100%}.home-hero{margin-bottom:10px}.home-content{order:2}}.pre-dashboard{margin:auto;padding-bottom:150px;padding-top:120px;width:320px}.pre-dashboard .logout,.pre-dashboard .logout span{color:#47565799;font-family:Arial,Helvetica,sans-serif;font-size:14px;margin-bottom:0;margin-top:20px}.pre-dashboard .logout span{color:#ef5b5b;cursor:pointer;text-decoration:underline}.fetching-courses{align-items:center;background-color:#fffbfe;box-shadow:0 0 10px 0 #0000001a;display:flex;flex-direction:column;justify-content:center;min-height:250px;padding:30px 20px}.fetching-courses h1{font-size:20px;font-weight:600;margin-bottom:20px;text-align:center}.loading-balls{display:flex;justify-content:center;margin-top:20px}.loading-ball{background-color:#dceed1;border-radius:50%;height:20px;margin:0 5px;width:20px}.loading-ball:first-child{animation:bounce .5s infinite alternate}.loading-ball:nth-child(2){animation:bounce .5s .1s infinite alternate}.loading-ball:nth-child(3){animation:bounce .5s .2s infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-10px)}}.course-list{background-color:#fffbfe;box-shadow:0 0 10px 0 #0000001a;padding:30px 20px}.course-list h1{font-size:20px;font-weight:600;margin-bottom:10px}.course-list p{font-size:14px;font-weight:400;line-height:1.5;margin-bottom:10px;text-align:justify}.course-list ul{list-style-type:none;margin-bottom:20px;padding:0}.course-list li{align-items:center;background-color:#dceed1;border-radius:5px;display:flex;font-family:Courier New,Courier,monospace;justify-content:space-between;margin-bottom:10px;padding:10px}.course-list button{background-color:#ef5b5b;border:none;border-radius:5px;color:#fff;cursor:pointer;padding:10px 20px}.dashboard{padding:120px 5% 100px}.dashboard h1{color:#475657}.dashboard .logout,.dashboard .logout span{color:#47565799;font-family:Arial,Helvetica,sans-serif;margin-top:5px}.dashboard .logout span{color:#ef5b5b;cursor:pointer;text-decoration:underline}.timetable-container{align-items:start;display:flex;height:81.9vh;justify-content:space-around;margin-top:30px}.timetable-grid{width:70%}.timetable-items{-ms-overflow-style:none;background-color:#fffbfe;border:1px solid #475657;height:100%;overflow:scroll;padding:2% 3%;scrollbar-color:#0000;scrollbar-width:none;width:30%}.timetable-items::-webkit-scrollbar{display:none}.timetable-items h2{color:#475657;font-size:20px;font-weight:600;margin-bottom:10px}.timetable-item{border-bottom:1px solid #475657;padding:10px 0;position:relative}.timetable-item h3,.timetable-item p{font-family:Courier New,Courier,monospace}.timetable-item p{color:#ef5b5b;font-size:14px;font-weight:600;margin-bottom:5px;margin-top:5px}.timetable-item p span{color:#000;font-family:Courier New,Courier,monospace;font-weight:400}.timetable-edit-btn{background-color:#ef5b5b;border:none;border-radius:10px;color:#fff;cursor:pointer;padding:5px 10px;position:absolute;right:5px;top:5px}.edit-timing-modal{background-color:#0000001a;display:none;height:100%;left:0;overflow:auto;position:fixed;top:0;width:100%;z-index:1000}.edit-timing-inner{background-color:#fffbfe;border-radius:10px;margin:10% auto;padding:20px;position:relative;width:320px}.edit-timing-inner h4{font-size:20px;font-weight:600;margin-bottom:20px}.edit-timing-section{margin-bottom:20px}.edit-timing-section h5{font-size:16px;font-weight:600;margin-bottom:10px}#select-lab-day,#select-tutorial{border:1px solid #475657;border-radius:5px;padding:10px;width:100%}#select-lab-day:focus,#select-tutorial:focus{outline:none}.edit-timing-inner button{background-color:#ef5b5b;border:none;border-radius:5px;color:#fff;cursor:pointer;padding:10px 20px}.select-lab-time{align-items:center;display:flex;justify-content:space-between;margin-top:10px}.select-lab-time-comp{width:48%}.select-lab-time-comp p{color:#000;font-family:Kodchasan,sans-serif;font-size:14px;font-weight:600;margin-bottom:10px}.select-lab-time-comp input{border:1px solid #475657;border-radius:5px;padding:10px;width:90%}.select-lab-time-comp input:focus{outline:none}.download-timetable-btn{background-color:#ef5b5b;border:none;border-radius:5px;color:#fff;cursor:pointer;margin-top:20px;padding:10px 20px}@media (max-width:1024px){.timetable-container{flex-direction:column;height:auto}.timetable-grid{margin-bottom:20px;width:100%}.timetable-items{width:100%}}.invalid-kerberos-overlay{align-items:center;background-color:#0009;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:9999}.invalid-kerberos-popup{animation:popupFadeIn .3s ease-out;background-color:#fffbfe;border-radius:15px;box-shadow:0 10px 40px #0000004d;max-width:450px;padding:40px;text-align:center;width:90%}@keyframes popupFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.invalid-kerberos-popup h2{color:#ef5b5b;font-size:24px;font-weight:600;margin-bottom:15px}.invalid-kerberos-popup p{color:#475657;font-size:16px;line-height:1.6;margin-bottom:15px}.invalid-kerberos-popup p:last-of-type{margin-bottom:25px}.popup-buttons{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.invalid-kerberos-popup button{background-color:#ef5b5b;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 30px;transition:background-color .3s ease,transform .2s ease}.invalid-kerberos-popup button:hover{background-color:#d94848;transform:translateY(-2px)}.invalid-kerberos-popup button:active{transform:translateY(0)}.invalid-kerberos-popup button.secondary-btn{background-color:#9984d4}.invalid-kerberos-popup button.secondary-btn:hover{background-color:#7a68b8}.timetable-grid{align-items:flex-start;background-color:#fffbfe;border:1px solid #475657;display:flex;height:100%;justify-content:space-between;margin-right:2%;overflow:scroll;padding:20px}.time-headers{border-collapse:collapse;min-width:50px;width:7%}.time-headers tr,.time-headers tr:first-child{height:80px}.time-headers tr td{font-size:12px;padding-right:10px;text-align:right}.timetable-grid-cells{border-collapse:collapse;min-width:700px;position:relative;width:93%}.timetable-grid-cells tr{height:80px;width:100%}.timetable-grid-cells tr:first-child{height:40px}.timetable-grid-cells tr th{width:20%}.timetable-grid-cells,.timetable-grid-cells td,.timetable-grid-cells th{border:1px solid #47565733}.timetable-element{background-color:#ef5b5b33;border-radius:5px;padding:10px;position:absolute;width:20%}.timetable-element-left{background-color:#ef5b5b;border-radius:5px 0 0 5px;height:100%;left:0;position:absolute;top:0;width:5px}.timetable-element h5{font-size:14px;font-weight:600}@media (max-width:1024px){.timetable-grid{height:80vh}}:root{--cf-primary:#ef5b5b;--cf-secondary:#9984d4;--cf-text:#475657;--cf-text-light:#6b7c7d;--cf-bg:#fffbfe;--cf-card-bg:#fffbfe;--cf-success:#dceed199;--cf-border:#d0d5dd}.cf-container{background:#fffbfe;background:var(--cf-bg);min-height:100vh;padding-bottom:20px;padding-top:100px}.cf-header{align-items:center;background:#fffbfe;background:var(--cf-card-bg);border-bottom:1px solid #d0d5dd;border-bottom:1px solid var(--cf-border);display:flex;gap:16px;justify-content:center;padding:16px 0}.cf-header-updated{font-size:12px;white-space:nowrap}.cf-footer-bar,.cf-header-updated{color:#6b7c7d;color:var(--cf-text-light)}.cf-footer-bar{background:#fffbfe;background:var(--cf-card-bg);border-top:1px solid #d0d5dd;border-top:1px solid var(--cf-border);font-size:11px;padding:8px 5%;text-align:left}.cf-title{font-size:28px;font-weight:700;margin:0 0 16px}.cf-title-dash{color:#ef5b5b;color:var(--cf-primary)}.cf-title-board{color:#9984d4;color:var(--cf-secondary)}.cf-header-subtitle{color:#6b7c7d;color:var(--cf-text-light);font-size:14px;line-height:1.5;margin:0 0 16px;text-align:center}@media (max-width:768px){.cf-header-subtitle{font-size:12px;margin-bottom:12px}}.cf-tabs{display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-start;margin:0 auto;max-width:1200px;padding:0 5%;width:100%}.cf-tab{align-items:center;background:#fffbfe;background:var(--cf-bg);border:1px solid #d0d5dd;border:1px solid var(--cf-border);border-radius:8px;color:#6b7c7d;color:var(--cf-text-light);cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s ease}.cf-tab:hover{border-color:#9984d4;border-color:var(--cf-secondary);color:#475657;color:var(--cf-text)}.cf-tab.active{background:#ef5b5b;background:var(--cf-primary);border-color:#ef5b5b;border-color:var(--cf-primary);color:#fff}.cf-tab-icon{font-size:16px}.cf-mobile-top-bar{display:none}.cf-mobile-view .cf-header{display:none!important}.cf-mobile-view.cf-container{background:#fffbfe;bottom:70px!important;display:flex!important;flex-direction:column!important;left:0!important;overflow:hidden!important;padding-bottom:0!important;padding-top:0!important;position:fixed!important;right:0!important;top:0!important;z-index:2000!important}.cf-mobile-view .cf-mobile-top-bar{align-items:center;background:#ef5b5b!important;box-shadow:0 2px 8px #00000026;color:#fff!important;display:flex!important;flex-shrink:0!important;height:60px!important;justify-content:center;min-height:60px!important;padding:0 20px;position:relative;z-index:2100!important}.cf-mobile-view .cf-mobile-title{font-size:18px;font-weight:700;z-index:101}.cf-mobile-view .cf-content{background:#fffbfe;flex:1 1!important;min-height:0!important;overflow-y:auto!important;padding:16px 16px 100px!important;position:relative;z-index:2005}.cf-mobile-view .cf-panel{background:#fff!important;border-radius:12px;box-shadow:0 2px 8px #0000000d;min-height:100px;padding:16px;position:relative;z-index:2006}.cf-nav-mobile{background:#fffbfe;border-top:1px solid #d0d5dd;border-top:1px solid var(--cf-border);bottom:0!important;box-shadow:0 -4px 12px #00000014;display:none;left:0!important;padding:8px 0 max(8px,env(safe-area-inset-bottom));position:fixed!important;right:0!important;width:100%!important;z-index:9999!important}.cf-mobile-view .cf-nav-mobile{display:flex!important}@media (max-width:768px){.cf-nav-mobile{display:flex!important}}.cf-nav-mobile-btn{align-items:center;background:none;border:none;color:#6b7c7d;color:var(--cf-text-light);cursor:pointer;display:flex;flex:1 1;flex-direction:column;gap:4px;padding:8px 4px;transition:color .2s ease}.cf-nav-mobile-btn svg{height:20px;width:20px}.cf-nav-mobile-btn span:last-child{font-size:11px;font-weight:500}.cf-nav-mobile-btn.active svg{stroke-width:2.5}.cf-nav-mobile-btn.active{color:#ef5b5b;color:var(--cf-primary)}.cf-content{margin:0 auto;max-width:1200px;padding:24px 5%}.cf-panel{background:#fffbfe;background:var(--cf-card-bg);border:1px solid #d0d5dd;border:1px solid var(--cf-border);border-radius:16px;box-shadow:0 2px 12px #0000000a;padding:24px}.cf-panel-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}.cf-panel-header h2{color:#475657;color:var(--cf-text);font-size:20px;font-weight:600;margin:0}.cf-search-form{margin-bottom:24px}.cf-form-row{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px}.cf-flex-1{flex:1 1;min-width:150px}.cf-flex-2{flex:2 1;min-width:200px}.cf-browse-controls{align-items:flex-end;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.cf-browse-controls .cf-input-group{flex:1 1;min-width:200px}.cf-input-group{display:flex;flex-direction:column;gap:6px}.cf-input-group label{color:#6b7c7d;color:var(--cf-text-light);font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.cf-input-group input,.cf-input-group select{background:#fffbfe;background:var(--cf-bg);border:2px solid #d0d5dd;border:2px solid var(--cf-border);border-radius:10px;color:#475657;color:var(--cf-text);font-size:15px;padding:12px 14px;transition:border-color .2s ease}.cf-input-group input:focus,.cf-input-group select:focus{border-color:#ef5b5b;border-color:var(--cf-primary);outline:none}.cf-btn-primary{background:#ef5b5b;background:var(--cf-primary);border:1px solid #ef5b5b;border:1px solid var(--cf-primary);border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s ease;white-space:nowrap}.cf-btn-primary:hover{background:#e04a4a;transform:translateY(-1px)}.cf-btn-secondary{background:#fffbfe;background:var(--cf-bg);border:2px solid #d0d5dd;border:2px solid var(--cf-border);border-radius:8px;color:#475657;color:var(--cf-text);cursor:pointer;font-size:13px;font-weight:600;padding:10px 18px;transition:all .2s ease}.cf-btn-secondary:hover{border-color:#9984d4;border-color:var(--cf-secondary);color:#9984d4;color:var(--cf-secondary)}.cf-btn-back{background:none;border:2px solid #d0d5dd;border:2px solid var(--cf-border);border-radius:8px;color:#475657;color:var(--cf-text);cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.cf-btn-back:hover{border-color:#ef5b5b;border-color:var(--cf-primary);color:#ef5b5b;color:var(--cf-primary)}.cf-btn-refresh{align-items:center;background:none;border:2px solid #d0d5dd;border:2px solid var(--cf-border);border-radius:8px;color:#6b7c7d;color:var(--cf-text-light);cursor:pointer;display:flex;justify-content:center;margin-left:auto;padding:8px;transition:all .2s ease}.cf-btn-refresh:hover{border-color:#ef5b5b;border-color:var(--cf-primary);color:#ef5b5b;color:var(--cf-primary)}.cf-btn-refresh:disabled{cursor:not-allowed;opacity:.5}.cf-btn-refresh .spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.cf-autocomplete-wrapper{position:relative;width:100%}.cf-autocomplete-wrapper input{width:100%}.cf-autocomplete-dropdown{background:#fffbfe;background:var(--cf-card-bg);border:2px solid #d0d5dd;border:2px solid var(--cf-border);border-radius:10px;box-shadow:0 8px 24px #0000001f;left:0;margin-top:4px;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:100}.cf-autocomplete-item{align-items:center;cursor:pointer;display:flex;gap:12px;padding:12px 14px;transition:background .15s ease}.cf-autocomplete-item:hover{background:#fffbfe;background:var(--cf-bg)}.cf-ac-avatar{align-items:center;background:#9984d4;background:var(--cf-secondary);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:14px;font-weight:600;height:36px;justify-content:center;width:36px}.cf-ac-info{display:flex;flex-direction:column}.cf-ac-name{color:#475657;color:var(--cf-text);font-size:14px;font-weight:500}.cf-ac-kerberos{color:#6b7c7d;color:var(--cf-text-light);font-size:12px}.cf-student-card{align-items:center;background:#dceed199;background:var(--cf-success);border-radius:12px;display:flex;gap:16px;margin-bottom:24px;padding:20px}.cf-student-avatar{align-items:center;background:#9984d4;background:var(--cf-secondary);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:22px;font-weight:600;height:56px;justify-content:center;width:56px}.cf-student-info h3{color:#475657;color:var(--cf-text);font-size:18px;margin:0 0 4px}.cf-student-info p{color:#6b7c7d;color:var(--cf-text-light);font-size:14px;margin:0}.cf-semester-block{border-bottom:1px solid #d0d5dd;border-bottom:1px solid var(--cf-border);margin-bottom:24px;padding-bottom:24px}.cf-semester-block:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.cf-semester-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:14px}.cf-semester-badge{background:linear-gradient(135deg,#ef5b5b,#f77);background:linear-gradient(135deg,var(--cf-primary),#f77);border-radius:6px;color:#fff;font-size:13px;font-weight:600;padding:6px 14px}.cf-course-count{color:#6b7c7d;color:var(--cf-text-light);font-size:13px;margin-left:auto}.cf-course-chips{display:flex;flex-wrap:wrap;gap:10px}.cf-course-chip{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 1px 2px #0000000d;color:#475657;color:var(--cf-text);cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s ease}.cf-course-chip:hover{transform:translateY(-1px)}.cf-filter-box{align-items:center;display:flex;gap:12px;margin-bottom:20px}.cf-filter-box input{background:#fffbfe;background:var(--cf-bg);border:2px solid #d0d5dd;border:2px solid var(--cf-border);border-radius:10px;flex:1 1;font-size:14px;padding:12px 16px}.cf-filter-box input:focus{border-color:#ef5b5b;border-color:var(--cf-primary);outline:none}.cf-filter-count{color:#6b7c7d;color:var(--cf-text-light);font-size:13px;white-space:nowrap}.cf-course-grid,.cf-room-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr)}.cf-room-groups{display:flex;flex-direction:column;gap:24px}.cf-room-building{background:#fffbfe;background:var(--cf-card-bg);border:1px solid #d0d5dd;border:1px solid var(--cf-border);border-radius:16px;padding:20px}.cf-building-name{align-items:center;border-bottom:2px solid #d0d5dd;border-bottom:2px solid var(--cf-border);color:#475657;color:var(--cf-text);display:flex;font-size:18px;font-weight:700;gap:10px;margin:0 0 16px;padding-bottom:12px}.cf-building-name svg{color:#ef5b5b;color:var(--cf-primary)}.cf-building-count{background:#fffbfe;background:var(--cf-bg);border-radius:20px;color:#6b7c7d;color:var(--cf-text-light);font-size:13px;font-weight:500;margin-left:auto;padding:4px 10px}.cf-building-floors{display:flex;flex-direction:column;gap:16px}.cf-floor-name,.cf-room-floor{padding-left:8px}.cf-floor-name{border-left:3px solid #9984d4;border-left:3px solid var(--cf-secondary);color:#9984d4;color:var(--cf-secondary);font-size:14px;font-weight:600;margin:0 0 10px}.cf-course-card,.cf-room-card{background:#fffbfe;background:var(--cf-bg);border:1px solid #d0d5dd;border:1px solid var(--cf-border);border-radius:12px;cursor:pointer;padding:18px;position:relative;transition:all .15s ease}.cf-course-card:hover,.cf-room-card:hover{background:#fffbfe;background:var(--cf-bg);border-color:#9984d4;border-color:var(--cf-secondary);box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.cf-course-code,.cf-room-name{color:#475657;color:var(--cf-text);display:block;font-size:15px;font-weight:700}.cf-course-meta,.cf-room-meta{color:#6b7c7d;color:var(--cf-text-light);display:block;font-size:12px;margin-top:6px}.cf-cached-badge{color:#22c55e;font-size:12px;position:absolute;right:8px;top:8px}.cf-students-list{border:1px solid #d0d5dd;border:1px solid var(--cf-border);border-radius:12px;display:flex;flex-direction:column;gap:4px;max-height:500px;overflow-y:auto;padding:8px}.cf-student-row{align-items:center;border:1px solid #0000;border-radius:10px;cursor:pointer;display:flex;gap:14px;padding:14px;transition:all .15s ease}.cf-student-row:hover{background:#fffbfe;background:var(--cf-bg);border-color:#d0d5dd;border-color:var(--cf-border)}.cf-student-avatar-sm{align-items:center;background:#9984d4;background:var(--cf-secondary);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:15px;font-weight:600;height:40px;justify-content:center;width:40px}.cf-student-info-row{display:flex;flex-direction:column;gap:2px}.cf-student-name{color:#475657;color:var(--cf-text);font-size:14px;font-weight:500}.cf-student-kerberos{color:#6b7c7d;color:var(--cf-text-light);font-size:12px}.cf-room-schedule{display:flex;flex-direction:column;gap:20px}.cf-schedule-day h4{border-bottom:2px solid #ef5b5b;border-bottom:2px solid var(--cf-primary);color:#475657;color:var(--cf-text);display:inline-block;font-size:15px;font-weight:600;margin:0 0 12px;padding-bottom:8px}.cf-schedule-slots{display:flex;flex-direction:column;gap:8px}.cf-schedule-slot{align-items:center;background:#fffbfe;background:var(--cf-bg);border-radius:8px;display:flex;gap:16px;padding:12px}.cf-slot-time{color:#9984d4;color:var(--cf-secondary);font-size:13px;font-weight:600;min-width:110px}.cf-slot-courses{color:#475657;color:var(--cf-text);font-size:14px;font-weight:500}.cf-badge{background:#9984d4;background:var(--cf-secondary);color:#fff;font-weight:600}.cf-badge,.cf-badge-secondary{border-radius:6px;font-size:12px;padding:5px 12px}.cf-badge-secondary{background:#fffbfe;background:var(--cf-bg);color:#6b7c7d;color:var(--cf-text-light);font-weight:500}.cf-empty-state{background:linear-gradient(135deg,#ef5b5b05,#9984d405);border:1px dashed #d0d5dd;border:1px dashed var(--cf-border);border-radius:12px;padding:48px 24px;text-align:center}.cf-empty-icon{color:#6b7c7d;color:var(--cf-text-light);font-size:48px;margin-bottom:16px}.cf-empty-state h3{color:#475657;color:var(--cf-text);font-size:18px;margin:0 0 8px}.cf-empty-state p{font-size:14px;line-height:1.6;margin:0 0 8px}.cf-empty-state p,.cf-hint{color:#6b7c7d;color:var(--cf-text-light)}.cf-hint{font-size:13px;margin-top:12px!important}.cf-empty{color:#6b7c7d;color:var(--cf-text-light);font-size:14px;padding:24px;text-align:center}.cf-loading{display:flex;justify-content:center;padding:48px}.cf-spinner{animation:cf-spin .8s linear infinite;border:3px solid #d0d5dd;border-top-color:#ef5b5b;border:3px solid var(--cf-border);border-radius:50%;border-top-color:var(--cf-primary);height:36px;width:36px}@keyframes cf-spin{to{transform:rotate(1turn)}}.cf-error{background:#fee2e2;border-radius:10px;color:#b91c1c;font-size:14px;font-weight:500;margin-bottom:20px;padding:14px 18px}@media (min-width:768px){.cf-container{padding-bottom:0}.cf-course-grid,.cf-room-grid{grid-template-columns:repeat(4,1fr)}}@media (min-width:1024px){.cf-course-grid,.cf-room-grid{grid-template-columns:repeat(5,1fr)}}@media (min-width:1280px){.cf-course-grid,.cf-room-grid{grid-template-columns:repeat(6,1fr)}}@media (max-width:600px){.cf-form-row{flex-direction:column}.cf-btn-primary,.cf-flex-1,.cf-flex-2{width:100%}.cf-browse-controls{flex-direction:column}.cf-browse-controls .cf-btn-primary,.cf-browse-controls .cf-input-group{width:100%}}.cf-view-toggle{display:flex;gap:4px;margin-left:auto}.cf-view-btn{align-items:center;background:#fff;border:1px solid #d0d5dd;border:1px solid var(--cf-border);color:#475657;color:var(--cf-text);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease}.cf-view-btn:first-child{border-radius:6px 0 0 6px}.cf-view-btn:last-child{border-radius:0 6px 6px 0}.cf-view-btn.active{background:#ef5b5b;background:var(--cf-primary);border-color:#ef5b5b;border-color:var(--cf-primary);color:#fff;font-weight:600}.cf-view-btn:hover:not(.active){background:var(--cf-bg-light);border-color:#ef5b5b;border-color:var(--cf-primary);color:#ef5b5b;color:var(--cf-primary)}.cf-student-stats{display:flex;gap:24px;margin-left:auto}.cf-stat{align-items:center;display:flex;flex-direction:column}.cf-stat-value{color:#475657;color:var(--cf-text);font-size:24px;font-weight:700}.cf-stat-label{color:#6b7c7d;color:var(--cf-text-light);font-size:11px;font-weight:500;text-transform:uppercase}.cf-timetable{margin-top:16px;overflow-x:auto}.cf-conflict-warning{background:#fee2e2;border-radius:8px;color:#b91c1c;font-size:13px;font-weight:500;margin-bottom:16px;padding:10px 16px}.cf-timetable-grid{grid-gap:0;background:#fff;border:1px solid #eee;border-radius:12px;display:grid;gap:0;grid-template-columns:60px repeat(5,1fr);min-width:600px;overflow:hidden}.cf-timetable-corner{border-right:1px solid #eee}.cf-timetable-corner,.cf-timetable-day-header{background:#fff;border-bottom:1px solid #eee;padding:12px}.cf-timetable-day-header{color:#475657;color:var(--cf-text);font-size:13px;font-weight:600;text-align:center;text-transform:capitalize}.cf-timetable-times{background:#fffbfe;background:var(--cf-bg)}.cf-timetable-time{align-items:flex-start;color:#888;display:flex;font-size:11px;justify-content:flex-end;padding:2px 8px 0}.cf-timetable-day-col,.cf-timetable-time{background:#fff;border-right:1px solid #eee}.cf-timetable-day-col{background-image:repeating-linear-gradient(180deg,#f5f5f5 0,#f5f5f5 1px,#0000 0,#0000 60px);position:relative}.cf-timetable-event{border-left-style:solid;border-left-width:4px;box-shadow:none;color:#475657;color:var(--cf-text);cursor:default;display:flex;flex-direction:column;font-size:11px;justify-content:center;left:2px;overflow:hidden;padding:2px 8px;position:absolute;right:2px;z-index:10}.cf-timetable-event.conflict{border:2px solid #7f1d1d}.cf-event-code{font-size:12px;font-weight:600}.cf-event-code,.cf-event-room{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cf-event-room{font-size:10px;opacity:.9}@media (max-width:768px){.cf-timetable-grid{min-width:550px}.cf-student-stats{justify-content:center;margin-top:12px;width:100%}.cf-student-card{flex-wrap:wrap}}.cf-analytics{background:#fffbfe;background:var(--cf-bg);border-radius:12px;margin-bottom:24px;padding:20px}.cf-analytics-title{color:#475657;color:var(--cf-text);font-size:16px;font-weight:600;margin:0 0 16px}.cf-analytics-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}@media (max-width:768px){.cf-analytics-grid{grid-template-columns:1fr}}.cf-analytics-card{background:#fffbfe;background:var(--cf-bg);border:1px solid #d0d5dd;border:1px solid var(--cf-border);border-radius:10px;padding:16px}.cf-analytics-card h5{color:#6b7c7d;color:var(--cf-text-light);font-size:12px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.cf-program-bars{display:flex;flex-direction:column;gap:8px}.cf-dist-bar{align-items:center;display:flex;gap:8px}.cf-dist-label{color:#475657;color:var(--cf-text);flex-shrink:0;font-size:12px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:85px}.cf-dist-track{background:#d0d5dd;background:var(--cf-border);border-radius:4px;flex:1 1;height:8px;overflow:hidden}.cf-dist-fill{background:linear-gradient(90deg,#ef5b5b,#9984d4);background:linear-gradient(90deg,var(--cf-primary),var(--cf-secondary));border-radius:4px;height:100%;transition:width .3s ease}.cf-dist-value{color:#6b7c7d;color:var(--cf-text-light);flex-shrink:0;font-size:11px;text-align:right;width:60px}.cf-year-chips{display:flex;flex-wrap:wrap;gap:8px}.cf-year-chip{background:#fffbfe;background:var(--cf-bg);border-radius:6px;color:#6b7c7d;color:var(--cf-text-light);font-size:13px;padding:6px 12px}.cf-year-chip strong{color:#ef5b5b;color:var(--cf-primary);font-weight:600}.cf-analytics-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.cf-analytics-card-header h5{margin:0}.cf-btn-details{background:#9984d4;background:var(--cf-secondary);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:all .2s ease}.cf-btn-details:hover{background:#7a68b8;transform:translateY(-1px)}.cf-dist-bar.others .cf-dist-fill{background:linear-gradient(90deg,#94a3b8,#64748b)}.cf-dist-bar.others .cf-dist-label{color:#6b7c7d;color:var(--cf-text-light);font-style:italic}.cf-modal-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:10000}.cf-modal{animation:modalSlideIn .3s ease;background:#fffbfe;background:var(--cf-card-bg);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:80vh;max-width:700px;overflow:hidden;width:100%}.cf-modal.cf-modal-large{max-width:900px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.cf-modal-header{align-items:center;background:linear-gradient(135deg,#ef5b5b,#9984d4);background:linear-gradient(135deg,var(--cf-primary),var(--cf-secondary));border-bottom:1px solid #d0d5dd;border-bottom:1px solid var(--cf-border);display:flex;justify-content:space-between;padding:20px 24px}.cf-modal-header h3{color:#fff;font-size:18px;font-weight:600;margin:0}.cf-modal-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;height:36px;justify-content:center;transition:background .2s;width:36px}.cf-modal-close:hover{background:#ffffff4d}.cf-modal-body{max-height:calc(80vh - 80px);overflow-y:auto;padding:20px 24px 100px}.cf-detailed-table{border:1px solid #d0d5dd;border:1px solid var(--cf-border);border-radius:8px;display:flex;flex-direction:column;overflow:hidden}.cf-detailed-header{background:linear-gradient(135deg,#ef5b5b1a,#9984d41a);color:#475657;color:var(--cf-text);font-size:13px;font-weight:600}.cf-detailed-header,.cf-detailed-row{grid-gap:12px;border-bottom:1px solid #d0d5dd;border-bottom:1px solid var(--cf-border);display:grid;gap:12px;grid-template-columns:100px 1fr 140px 70px 60px;padding:12px 16px}.cf-detailed-row{align-items:center;transition:background .2s}.cf-detailed-row:hover{background:#fffbfe;background:var(--cf-bg)}.cf-detailed-row:last-child{border-bottom:none}.cf-prog-short{color:#ef5b5b;color:var(--cf-primary);font-size:13px;font-weight:600}.cf-prog-full{color:#6b7c7d;color:var(--cf-text-light);font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cf-prog-count{color:#475657;color:var(--cf-text);font-weight:600;text-align:right}.cf-prog-percent{color:#9984d4;color:var(--cf-secondary);font-size:12px;font-weight:500;text-align:right}.cf-dept-name,.cf-prog-dept{color:#475657;color:var(--cf-text);display:block;font-size:13px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:600px){.cf-detailed-table{-webkit-overflow-scrolling:touch;border-radius:8px;display:block;overflow-x:auto;position:relative}.cf-detailed-header,.cf-detailed-row{border-bottom:1px solid #d0d5dd;border-bottom:1px solid var(--cf-border);display:flex;gap:0;padding:0;width:-webkit-max-content;width:max-content}.cf-detailed-header span,.cf-detailed-row>div,.cf-detailed-row>span{align-items:center;border-right:1px solid #0000;display:flex;flex-shrink:0;font-size:13px;padding:10px 12px}.cf-detailed-header span:first-child,.cf-detailed-row>span:first-child{background:#fff;border-right:1px solid #d0d5dd;border-right:1px solid var(--cf-border);font-weight:600;left:0;position:-webkit-sticky;position:sticky;z-index:10}.cf-detailed-header{background:#fdf2f2;padding:0;position:-webkit-sticky;position:sticky;top:0;z-index:20}.cf-detailed-header span:first-child{background:#fdf2f2;z-index:30}.cf-detailed-row:hover,.cf-detailed-row:hover>span:first-child{background:#fffbfe;background:var(--cf-bg)}.cf-detailed-table:not(.cf-dept-table) span:first-child{width:85px}.cf-detailed-table:not(.cf-dept-table) span:nth-child(2){width:180px}.cf-detailed-table:not(.cf-dept-table) span:nth-child(3){display:flex!important;width:140px}.cf-detailed-table:not(.cf-dept-table) span:nth-child(4){justify-content:flex-end;width:70px}.cf-detailed-table:not(.cf-dept-table) span:nth-child(5){justify-content:flex-end;width:60px}.cf-dept-table span:first-child{display:block!important;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:150px}.cf-dept-table span:nth-child(2){justify-content:flex-end;width:80px}.cf-dept-table span:nth-child(3){justify-content:flex-end;width:70px}}.cf-analytics-tabs{display:flex;flex-direction:column;gap:28px}.cf-analytics-section{border-bottom:1px solid #d0d5dd;border-bottom:1px solid var(--cf-border);padding-bottom:24px}.cf-analytics-section:last-child{border-bottom:none;padding-bottom:0}.cf-analytics-section h4{align-items:center;color:#475657;color:var(--cf-text);display:flex;font-size:16px;font-weight:600;gap:10px;margin:0 0 16px}.cf-analytics-section h4 svg{color:#ef5b5b;color:var(--cf-primary);flex-shrink:0}.cf-year-dept-table{-webkit-overflow-scrolling:touch;border:1px solid #d0d5dd;border:1px solid var(--cf-border);border-radius:8px;max-height:500px;overflow-x:auto;position:relative}.cf-year-dept-header,.cf-year-dept-row{display:flex;gap:0;width:-webkit-max-content;width:max-content}.cf-year-dept-header{background:#fdf2f2;border-bottom:2px solid #d0d5dd;border-bottom:2px solid var(--cf-border);padding:0;position:-webkit-sticky;position:sticky;top:0;z-index:20}.cf-year-dept-row{background:#fff;border-bottom:1px solid #d0d5dd;border-bottom:1px solid var(--cf-border);padding:0}.cf-year-dept-row:last-child{border-bottom:none}.cf-dept-col{align-items:center;background:#fff;border-right:1px solid #d0d5dd;border-right:1px solid var(--cf-border);color:#475657;color:var(--cf-text);display:flex;flex-shrink:0;font-size:13px;font-weight:500;left:0;padding:12px 16px;position:-webkit-sticky;position:sticky;width:140px;z-index:10}.cf-year-dept-header .cf-dept-col{background:#fdf2f2;font-weight:600;z-index:30}.cf-year-dept-row:hover,.cf-year-dept-row:hover .cf-dept-col{background:#fffbfe;background:var(--cf-bg)}.cf-year-col{align-items:center;border-right:1px solid #0000;color:#6b7c7d;color:var(--cf-text-light);display:flex;flex-shrink:0;font-size:13px;justify-content:center;padding:12px 4px;text-align:center;width:60px}.cf-year-dept-header .cf-year-col{color:#6b7c7d;color:var(--cf-text-light);font-weight:600}.cf-year-dept-row .cf-year-col{color:#475657;color:var(--cf-text)}.cf-total-col{align-items:center;border-left:1px solid #d0d5dd;border-left:1px solid var(--cf-border);display:flex;flex-shrink:0;font-size:13px;font-weight:600;justify-content:center;padding:12px 4px;text-align:center;width:60px}.cf-total-col,.cf-year-dept-header .cf-total-col{color:#ef5b5b;color:var(--cf-primary)}@media (max-width:600px){.cf-detailed-header,.cf-detailed-row{gap:8px;grid-template-columns:70px 1fr 50px 40px;padding:10px 12px}.cf-dept-name,.cf-prog-dept{display:none}.cf-modal{max-height:90vh}.cf-modal.cf-modal-large{max-width:100%}.cf-modal-body{max-height:calc(90vh - 80px)}.cf-dept-col{min-width:100px}.cf-total-col,.cf-year-col{min-width:45px}}.cf-free-rooms-info{align-items:center;background:linear-gradient(135deg,#dceed199,#e8f5e9);background:linear-gradient(135deg,var(--cf-success),#e8f5e9);border-radius:12px;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:20px;padding:16px 20px}.cf-time-badge{align-items:center;background:#fffbfe;background:var(--cf-bg);border-radius:20px;box-shadow:0 2px 8px #0000001a;display:flex;font-weight:600;gap:8px;padding:8px 16px}.cf-info-message,.cf-time-badge{color:#475657;color:var(--cf-text)}.cf-info-message{font-size:14px;margin:0}.cf-room-stats{display:flex;flex-wrap:wrap;gap:16px}.cf-stat-free,.cf-stat-occupied,.cf-stat-total{border-radius:16px;font-size:13px;font-weight:600;padding:6px 14px}.cf-stat-free{background:#4caf50;color:#fff}.cf-stat-occupied{background:#ef5b5b;background:var(--cf-primary);color:#fff}.cf-stat-total{background:#9984d4;background:var(--cf-secondary);color:#fff}.cf-free-rooms-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.cf-free-room-card{align-items:center;background:#fffbfe;background:var(--cf-card-bg);border:2px solid #4caf50;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:8px;padding:16px;transition:all .2s ease}.cf-free-room-card:hover{background:#e8f5e9;box-shadow:0 4px 12px #4caf5033;transform:translateY(-2px)}.cf-free-room-card svg{color:#4caf50}.cf-free-room-card .cf-room-name{color:#475657;color:var(--cf-text);font-size:15px;font-weight:600}@media (max-width:480px){.cf-free-rooms-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.cf-free-room-card{padding:12px}.cf-free-rooms-info{align-items:flex-start;flex-direction:column}}.cf-semester-block-split{display:flex;flex-direction:column;gap:16px;height:100%}.cf-split-header{align-items:center;display:flex;gap:12px}.cf-split-container{display:flex;gap:20px;min-height:500px}.cf-split-main{background:#fff;border:1px solid #d0d5dd;border:1px solid var(--cf-border);border-radius:12px;box-shadow:0 1px 3px #0000000d;flex:1 1;overflow:hidden;padding:1px}.cf-split-sidebar{display:flex;flex-direction:column;flex-shrink:0;width:280px}.cf-split-sidebar h3{color:#475657;color:var(--cf-text);font-size:15px;font-weight:600;margin:0 0 12px}.cf-course-cards-list{display:flex;flex-direction:column;gap:10px}.cf-course-card-item{align-items:center;background:#fff;border:1px solid #d0d5dd;border:1px solid var(--cf-border);border-left-width:4px;border-radius:8px;box-shadow:0 1px 2px #00000005;display:flex;justify-content:space-between;padding:12px 14px;transition:all .2s ease}.cf-course-card-item:hover{border-color:#d1d5db;box-shadow:0 4px 8px #0000000f;transform:translateY(-2px)}.cf-card-info{display:flex;flex-direction:column}.cf-card-code{color:#475657;color:var(--cf-text);font-size:14px;font-weight:700;letter-spacing:.5px}.cf-card-edit-btn{align-items:center;background-color:#ef4444;border:none;border-radius:50%;box-shadow:0 2px 4px #ef444466;cursor:pointer;display:flex;height:28px;justify-content:center;transition:transform .2s,background-color .2s;width:28px}.cf-card-edit-btn:hover{background-color:#dc2626;transform:scale(1.1)}.cf-settings-section{margin-bottom:24px}.cf-settings-section:last-child{margin-bottom:0}.cf-settings-section h4{color:#6b7c7d;color:var(--cf-text-light);font-size:12px;font-weight:700;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.cf-color-grid{display:flex;flex-wrap:wrap;gap:12px}.cf-color-swatch{border:2px solid #0000;border-radius:50%;cursor:pointer;height:36px;transition:transform .2s,box-shadow .2s;width:36px}.cf-color-swatch:hover{box-shadow:0 0 0 2px #fff,0 0 0 4px #cbd5e1;transform:scale(1.1)}.cf-divider{background:#d0d5dd;background:var(--cf-border);border:none;height:1px;margin:20px 0}.cf-custom-events-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.cf-custom-event-item{align-items:center;background:#f1f5f9;border:1px solid #0000;border-radius:6px;display:flex;font-size:13px;justify-content:space-between;padding:8px 12px}.cf-custom-event-item:hover{background:#e2e8f0;border-color:#cbd5e1}.cf-event-info{display:flex;flex-direction:column}.cf-event-info strong{color:#475657;color:var(--cf-text)}.cf-event-info span{color:#6b7c7d;color:var(--cf-text-light);font-size:11px}.cf-add-event-form{background:#fff;border:1px solid #d0d5dd;border:1px solid var(--cf-border);border-radius:8px;display:flex;flex-direction:column;gap:12px;padding:16px}.cf-form-row.tight{align-items:flex-end;display:flex;gap:8px}.cf-form-row.tight .cf-form-group{flex:1 1}.cf-form-group label{color:#6b7c7d;color:var(--cf-text-light);display:block;font-size:12px;font-weight:600;margin-bottom:4px}.cf-form-group input,.cf-form-group select{background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:13px;outline:none;padding:8px 10px;transition:border-color .2s;width:100%}.cf-form-group input:focus,.cf-form-group select:focus{border-color:#ef5b5b;border-color:var(--cf-primary);box-shadow:0 0 0 2px #ef44441a}.cf-btn-delete{background:#0000;border:none;border-radius:4px;color:#ef4444;cursor:pointer;padding:4px;transition:background .2s}.cf-btn-delete:hover{background:#ef44441a}.cf-btn-primary.small-btn{align-items:center;background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;height:38px;padding:0 16px;transition:background .2s;white-space:nowrap}.cf-btn-primary.small-btn:hover{background:#dc2626}@media (min-width:1200px){.cf-container{margin:0 auto;max-width:1800px}.cf-content{padding:0 24px}.cf-split-container{gap:20px}.cf-split-sidebar{width:250px}}.cf-timetable{width:100%}.cf-timetable-grid{min-width:0;width:100%}.cf-split-main{display:flex;flex-direction:column}.cf-timetable-day-header{padding:8px}.cf-timetable-time{font-size:10px}.about-container{background:#fffbfe;min-height:100vh;padding:100px 5% 60px}.about-content{background:#fffbfe;border:1px solid #e9ecef;border-radius:16px;margin:0 auto;max-width:800px;padding:40px}.about-title{font-size:36px;font-weight:700;margin-bottom:32px;text-align:center}.about-title-class{color:#475657}.about-title-grid{color:#ef5b5b}.about-title-grid:after{content:""}.about-section{border-bottom:1px solid #e9ecef;margin-bottom:32px;padding-bottom:24px}.about-section:last-of-type{border-bottom:none}.about-section h2{color:#475657;font-size:20px;font-weight:600;margin-bottom:12px}.about-section p{color:#6b7c7d;font-size:15px;line-height:1.7}.about-features{list-style:none;margin:0;padding:0}.about-features li{border-bottom:1px solid #f0f0f0;color:#6b7c7d;line-height:1.6;padding:12px 0}.about-features li:last-child{border-bottom:none}.about-features li strong{color:#9984d4}.about-team{margin-bottom:12px}.about-team a{color:#9984d4;font-weight:500;text-decoration:none}.about-team a:hover{text-decoration:underline}.about-contributors{background:#f8f9fa;border-radius:8px;padding:16px}.about-contributors p{font-size:14px;margin:0}.about-version{align-items:center;display:flex;gap:12px;margin-bottom:12px}.version-history{display:flex;flex-direction:column;gap:20px}.version-item{background:#f8f9fa;border-left:4px solid #e9ecef;border-radius:12px;padding:20px}.version-item:first-child{background:linear-gradient(135deg,#fff5f5,#f8f9fa);border-left-color:#ef5b5b}.version-header{align-items:center;display:flex;gap:12px;margin-bottom:8px}.version-badge{background:#6b7c7d;border-radius:20px;color:#fff;font-size:13px;font-weight:600;padding:4px 12px}.version-badge.current{background:#ef5b5b}.version-label{color:#9984d4;font-size:12px;font-weight:600;text-transform:uppercase}.version-creator{color:#475657;font-size:14px;margin-bottom:6px}.version-creator a{color:#9984d4;font-weight:500}.version-desc{color:#6b7c7d;font-size:13px;line-height:1.5;margin:0}.version-date{color:#6b7c7d;font-size:14px}.version-notes{font-size:14px;font-style:italic}.about-section a{color:#9984d4;text-decoration:none}.about-section a:hover{text-decoration:underline}.about-footer{margin-top:8px;padding-top:24px;text-align:center}.about-footer p{color:#6b7c7d;font-size:14px}.about-footer a{color:#ef5b5b;font-weight:500;text-decoration:none}.about-footer a:hover{text-decoration:underline}@media (max-width:768px){.about-container{padding:80px 16px 40px}.about-content{padding:24px}.about-title{font-size:28px}}
/*# sourceMappingURL=main.73b73199.css.map*/