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}.login-container{align-items:center;background:#f2f5f7;display:flex;height:100vh;justify-content:center}.login-box{background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;max-width:400px;padding:2rem;text-align:center;width:90%}.login-logo{display:block;height:auto;margin:0 auto 1.5rem;max-width:80%;width:140px}.login-title{color:#333;font-size:1.8rem;margin-bottom:1rem}.login-form{display:flex;flex-direction:column;gap:1rem}.login-input{border:1px solid #ccc;border-radius:8px;font-size:1rem;padding:.8rem 1rem}.login-input:disabled{background:#eee}.login-button{align-items:center;background:#007bff;border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-weight:700;gap:.5rem;justify-content:center;padding:.8rem}.login-button:disabled{background:#6c9edb;cursor:not-allowed}.login-error{color:#d9534f;font-weight:700;margin-top:1rem}.spinner{border-right:3px solid #f3f3f3;border-top:3px solid #f3f3f3;border-color:#fff #fff #f3f3f3 #f3f3f3;border-style:solid;border-width:3px;height:20px;width:20px}@media (min-width:768px){.login-logo{width:180px}}:root{--primary-blue:#1a73e8;--primary-dark:#0d47a1;--primary-light:#e8f0fe;--secondary-purple:#6c63ff;--success:#34a853;--warning:#fbbc05;--error:#ea4335;--gray-50:#f8f9fa;--gray-100:#f1f3f4;--gray-200:#e8eaed;--gray-300:#dadce0;--gray-500:#9aa0a6;--gray-600:#757575;--gray-700:#5f6368;--gray-900:#202124;--shadow-sm:0 1px 3px #0000001f;--shadow-md:0 4px 6px #0000001a;--shadow-lg:0 10px 25px #0000001a;--border-radius:12px;--border-radius-sm:8px;--transition:all 0.3s ease}*{box-sizing:border-box;margin:0;padding:0}body{background:linear-gradient(135deg,#667eea,#764ba2);font-family:Segoe UI,system-ui,-apple-system,sans-serif;min-height:100vh}.home-container{background:#f8f9fa;background:var(--gray-50);min-height:100vh}.app-header{background:#fff;box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md);justify-content:space-between;padding:1rem 2rem;position:sticky;top:0;z-index:100}.app-header,.header-left{align-items:center;display:flex}.header-left{gap:2rem}.logo-section{align-items:center;display:flex;gap:1rem}.logo-icon{color:#1a73e8;color:var(--primary-blue);font-size:2rem}h1{color:#202124;color:var(--gray-900);font-size:1.5rem;font-weight:600;margin:0}.dept-info{align-items:center;display:flex;gap:.5rem}.dept-id{background:#e8f0fe;background:var(--primary-light);border-radius:8px;border-radius:var(--border-radius-sm);color:#1a73e8;color:var(--primary-blue);font-size:.875rem;font-weight:500;padding:.375rem .75rem}.header-right{gap:1rem}.header-right,.refresh-btn{align-items:center;display:flex}.refresh-btn{background:none;border:1px solid #dadce0;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--border-radius-sm);color:#5f6368;color:var(--gray-700);cursor:pointer;justify-content:center;padding:.5rem;transition:all .3s ease;transition:var(--transition)}.refresh-btn:hover{background:#f1f3f4;background:var(--gray-100);color:#1a73e8;color:var(--primary-blue)}.logout-btn{align-items:center;background:#ea4335;background:var(--error);border:none;border-radius:8px;border-radius:var(--border-radius-sm);color:#fff;cursor:pointer;display:flex;font-weight:500;gap:.5rem;padding:.625rem 1.25rem;transition:all .3s ease;transition:var(--transition)}.logout-btn:hover{background:#d32f2f;transform:translateY(-1px)}.main-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:320px 1fr;max-width:1400px;padding:2rem}.sidebar{background:#fff;border-radius:12px;border-radius:var(--border-radius);box-shadow:0 1px 3px #0000001f;box-shadow:var(--shadow-sm);height:fit-content;padding:1.5rem;position:sticky;top:100px}.sidebar-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.sidebar-header h2{align-items:center;color:#202124;color:var(--gray-900);display:flex;font-size:1.25rem;gap:.5rem;margin:0}.challenge-grid{display:flex;flex-direction:column;gap:.75rem}.challenge-card{background:#fff;border:2px solid #e8eaed;border:2px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius-sm);cursor:pointer;overflow:hidden;padding:1rem;position:relative;transition:all .3s ease;transition:var(--transition)}.challenge-card:hover{box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md);transform:translateY(-2px)}.challenge-card.active,.challenge-card:hover{border-color:#1a73e8;border-color:var(--primary-blue)}.challenge-card.active{background:#e8f0fe;background:var(--primary-light)}.card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.day-badge{background:#1a73e8;background:var(--primary-blue);border-radius:20px;color:#fff;font-size:.75rem;font-weight:600;padding:.25rem .75rem}.active-indicator{background:#34a853;background:var(--success);border-radius:50%;height:8px;width:8px}.card-content h4{color:#202124;color:var(--gray-900);font-size:1rem;margin-bottom:.25rem}.date{color:#9aa0a6;color:var(--gray-500);font-size:.875rem}.card-footer{justify-content:space-between;margin-top:1rem}.card-footer,.stats{align-items:center;display:flex}.stats{gap:.75rem}.completion-rate{color:#34a853;color:var(--success);font-size:.875rem;font-weight:600}.count{font-size:.875rem}.chevron,.count{color:#9aa0a6;color:var(--gray-500)}.dashboard{background:#fff;border-radius:12px;border-radius:var(--border-radius);box-shadow:0 1px 3px #0000001f;box-shadow:var(--shadow-sm);padding:1.5rem}.dashboard-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:2rem}.dashboard-title h2{align-items:center;color:#202124;color:var(--gray-900);display:flex;flex-wrap:wrap;font-size:1.5rem;gap:1rem;margin:0 0 1rem}.date-badge{background:#e8f0fe;background:var(--primary-light);border-radius:20px;color:#1a73e8;color:var(--primary-blue);font-size:.875rem;font-weight:500;padding:.25rem .75rem}.stats-summary{display:flex;flex-wrap:wrap;gap:1.5rem}.stat{align-items:center;color:#5f6368;color:var(--gray-700);display:flex;font-size:.875rem;gap:.5rem}.stat.highlight{background:#34a853;background:var(--success);border-radius:20px;color:#fff;font-weight:500;padding:.25rem .75rem}.controls{display:flex;gap:1rem}.search-box input{border:1px solid #dadce0;border:1px solid var(--gray-300);border-radius:8px;border-radius:var(--border-radius-sm);font-size:.875rem;min-width:250px;padding:.625rem 1rem;transition:all .3s ease;transition:var(--transition)}.search-box input:focus{border-color:#1a73e8;border-color:var(--primary-blue);box-shadow:0 0 0 3px #1a73e81a;outline:none}.user-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.user-card{background:#fff;border:1px solid #e8eaed;border:1px solid var(--gray-200);border-radius:8px;border-radius:var(--border-radius-sm);overflow:hidden;transition:all .3s ease;transition:var(--transition)}.user-card:hover{box-shadow:0 4px 6px #0000001a;box-shadow:var(--shadow-md)}.user-card-header{background:#f8f9fa;background:var(--gray-50);cursor:pointer;justify-content:space-between;padding:1.25rem}.user-card-header,.user-info{align-items:center;display:flex}.user-info{gap:1rem}.avatar{align-items:center;background:linear-gradient(135deg,#1a73e8,#6c63ff);background:linear-gradient(135deg,var(--primary-blue),var(--secondary-purple));border-radius:50%;color:#fff;display:flex;font-size:1.125rem;font-weight:600;height:40px;justify-content:center;width:40px}.user-role{color:#9aa0a6;color:var(--gray-500);font-size:.875rem;margin-top:.125rem}.user-status{gap:1rem}.status-badge,.user-status{align-items:center;display:flex}.status-badge{border-radius:20px;font-weight:500;gap:.375rem;padding:.375rem .75rem}.status-badge.completed{background:#e6f4ea;color:#34a853;color:var(--success)}.status-badge.pending{background:#fef7e0;color:#fbbc05;color:var(--warning)}.progress-circle{height:40px;position:relative;width:40px}.progress-circle svg{transform:rotate(-90deg)}.progress-bg{fill:none;stroke:#e8eaed;stroke:var(--gray-200);stroke-width:3}.progress-bar{fill:none;stroke:#34a853;stroke:var(--success);stroke-width:3;stroke-linecap:round;transition:stroke-dasharray .3s ease}.progress-circle span{color:#5f6368;color:var(--gray-700);font-size:.625rem;font-weight:600;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.expand-icon{color:#9aa0a6;color:var(--gray-500);transition:transform .3s ease}.expand-icon.expanded{transform:rotate(180deg)}.user-card-details{animation:slideDown .3s ease;border-top:1px solid #e8eaed;border-top:1px solid var(--gray-200);padding:1.25rem}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.task-summary h5{color:#5f6368;color:var(--gray-700);font-size:.875rem;margin-bottom:1rem}.task-list{display:flex;flex-direction:column;gap:.75rem}.task-item{background:#f8f9fa;background:var(--gray-50);border-radius:8px;border-radius:var(--border-radius-sm);justify-content:space-between;padding:.75rem}.task-info,.task-item{align-items:center;display:flex}.task-info{gap:.75rem}.task-status{align-items:center;border-radius:50%;display:flex;font-size:.75rem;height:20px;justify-content:center;width:20px}.task-status.completed{background:#34a853;background:var(--success);color:#fff}.task-status.pending{background:#fbbc05;background:var(--warning);color:#fff}.task-meta{color:#9aa0a6;color:var(--gray-500);font-size:.75rem}.completion-time{color:#34a853;color:var(--success);font-weight:500}.pending-text{color:#fbbc05;color:var(--warning);font-weight:500}.empty-dashboard{color:#9aa0a6;color:var(--gray-500);padding:4rem 2rem;text-align:center}.empty-icon{color:#dadce0;color:var(--gray-300);font-size:3rem;margin-bottom:1rem}.loading-container{align-items:center;color:#9aa0a6;color:var(--gray-500);display:flex;flex-direction:column;justify-content:center;padding:3rem}.spinner{animation:spin 1s linear infinite;border:3px solid #e8eaed;border-top-color:#1a73e8;border:3px solid var(--gray-200);border-radius:50%;border-top-color:var(--primary-blue);height:40px;margin-bottom:1rem;width:40px}.error-message{align-items:center;background:#fde8e8;border-radius:8px;border-radius:var(--border-radius-sm);color:#ea4335;color:var(--error);display:flex;font-size:.875rem;gap:.5rem;margin-bottom:1rem;padding:.75rem}@media (max-width:1024px){.main-content{display:block;max-width:100%;padding:1rem}.sidebar{background:#0000;box-shadow:none;height:auto;padding:0;position:static}.sidebar-header{display:none}.dashboard{margin-top:1rem}.user-grid{gap:1rem;grid-template-columns:1fr}.search-box input{min-width:100%}}@media (max-width:768px){.app-header{padding:1rem}.app-header,.header-left{flex-direction:column;gap:1rem}.header-left{align-items:flex-start;width:100%}.dashboard-header{align-items:stretch;flex-direction:column}.stats-summary{flex-wrap:wrap;gap:1rem}}@media (max-width:480px){.header-right{justify-content:space-between;width:100%}.logout-btn{flex:1 1;justify-content:center}.refresh-btn{flex:0 1}.user-card-header{align-items:flex-start;flex-direction:column;gap:1rem}.user-status{justify-content:space-between;width:100%}}.mobile-day-selector{display:none}@media (max-width:1024px){.mobile-day-selector{background:#fff;border-bottom:1px solid #e8eaed;border-bottom:1px solid var(--gray-200);display:block;margin-bottom:1.5rem;padding:1rem 1rem 0;position:sticky;top:70px;z-index:15}.current-day{align-items:center;background:#e8f0fe;background:var(--primary-light);border:1px solid #1a73e8;border:1px solid var(--primary-blue);border-radius:12px;border-radius:var(--border-radius);cursor:pointer;display:flex;gap:1rem;padding:1rem;transition:all .3s ease;transition:var(--transition)}.current-day:hover{background:#d1e3ff}.day-info h3{color:#202124;color:var(--gray-900);font-size:1.1rem;margin:0}.day-info span{color:#757575;color:var(--gray-600);font-size:.875rem}.chevron{font-size:1.25rem;margin-left:auto;transition:transform .25s ease}.chevron.rotated{transform:rotate(180deg)}.day-picker{background:#fff;border:1px solid #dadce0;border:1px solid var(--gray-300);border-radius:12px;border-radius:var(--border-radius);box-shadow:0 10px 25px #0000001a;box-shadow:var(--shadow-lg);margin:.75rem 0 1rem;max-height:60vh;overflow-y:auto}.day-option{border-bottom:1px solid #e8eaed;border-bottom:1px solid var(--gray-200);cursor:pointer;display:flex;flex-direction:column;gap:.25rem;padding:1rem 1.25rem;transition:all .3s ease;transition:var(--transition)}.day-option:last-child{border-bottom:none}.day-option.active,.day-option:hover{background:#e8f0fe;background:var(--primary-light)}.day-option .day-name{color:#202124;color:var(--gray-900);font-weight:500}.day-option .date{color:#757575;color:var(--gray-600);font-size:.85rem}.challenge-grid.desktop-only{display:none}}@media (min-width:1025px){.mobile-day-selector{display:none!important}.challenge-grid.desktop-only{display:flex;flex-direction:column;gap:.75rem}}.course-series-container{background:linear-gradient(135deg,#667eea,#764ba2);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;min-height:100vh}.meeting-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:15px;box-shadow:0 8px 25px #0000001a;margin:2rem auto;max-width:1200px;padding:2rem}.meeting-header{align-items:flex-start;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1.5rem}.meeting-info{flex:1 1}.meeting-title{color:#2c3e50;font-size:1.4rem;font-weight:600;line-height:1.3;margin:0 0 .5rem}.meeting-description{color:#666;font-size:.95rem;margin:0}.meeting-image{border-radius:8px;height:80px;margin-left:1.5rem;object-fit:cover;width:120px}.series-section{background:#f8f9fa;border-radius:10px;margin:1.5rem 0;padding:1.5rem}.series-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.series-info{flex:1 1}.series-title{color:#2c3e50;font-size:1.2rem;font-weight:600;margin:0 0 .25rem}.series-min-selection{color:#666;font-size:.9rem;margin:0}.series-stats{text-align:right}.completion-rate{display:block;font-size:1.3rem;font-weight:700;margin-bottom:.25rem}.modules-count{color:#666;font-size:.9rem}.modules-container{grid-gap:1rem;display:grid;gap:1rem;margin:1.5rem 0}.module-item{background:#fff;border-left:4px solid #667eea;border-radius:8px;padding:1.5rem}.module-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.module-info{flex:1 1}.module-title{color:#2c3e50;font-size:1.1rem;font-weight:500;line-height:1.3;margin:0 0 .5rem}.module-stats{color:#666;font-size:.9rem;margin:0}.module-thumbnail{border-radius:6px;height:60px;margin-left:1rem;object-fit:cover;width:80px}.staff-completion{border-top:1px solid #e9ecef;padding-top:1rem}.completion-title{color:#666;font-size:.95rem;font-weight:600;margin:0 0 1rem}.staff-list{grid-gap:.75rem;display:grid;gap:.75rem}.staff-completion-item{align-items:center;background:#f8f9fa;border-radius:6px;display:flex;flex-wrap:wrap;justify-content:space-between;padding:.75rem}.staff-info{flex:1 1;min-width:200px}.staff-name{color:#2c3e50;display:block;font-size:.9rem;font-weight:500;margin-bottom:.25rem}.staff-id{color:#666;font-size:.8rem}.completion-details{align-items:center;display:flex;flex-wrap:wrap;gap:1rem}.completion-status{border-radius:15px;color:#fff;font-size:.75rem;font-weight:600;min-width:100px;padding:.3rem .75rem;text-align:center;text-transform:uppercase}.completion-date{color:#666;font-size:.8rem;min-width:120px}.staff-progress-section{background:#fff;border-radius:8px;margin-top:1.5rem;padding:1.5rem}.staff-progress-list{grid-gap:1rem;display:grid;gap:1rem;margin-top:1rem}.staff-progress-item{background:#f8f9fa;border-radius:8px;padding:1rem}.progress-details{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;margin:.5rem 0}.progress-text{color:#666;font-size:.9rem}.status-badge{border-radius:15px;font-size:.75rem;padding:.3rem .75rem;text-transform:uppercase}.progress-bar-small{background:#e9ecef;border-radius:2px;height:4px;margin-top:.5rem;overflow:hidden}.progress-fill-small{border-radius:2px;height:100%;transition:width .3s ease}.back-button{background:#fff3;border:1px solid #ffffff4d;border-radius:25px;font-weight:600;margin-right:1rem;padding:.75rem 1.5rem;transition:all .3s ease}.back-button:hover{background:#ffffff4d;border-color:#ffffff80}@media (max-width:768px){.meeting-header{flex-direction:column}.meeting-image{align-self:flex-start;margin:1rem 0 0}.series-header{flex-direction:column}.series-stats{margin-top:.5rem;text-align:left}.module-header{flex-direction:column}.module-thumbnail{margin:1rem 0 0}.staff-completion-item{align-items:flex-start;flex-direction:column}.completion-details{justify-content:space-between;margin-top:.5rem;width:100%}.progress-details{align-items:flex-start;flex-direction:column;gap:.5rem}}.detailed-progress-container{background-color:#f5f5f5;min-height:100vh}.back-button{background:none;border:none;color:#fff;cursor:pointer;font-family:mont-medium,sans-serif;font-size:14px;margin-bottom:8px;padding:8px 0}.back-button:hover{text-decoration:underline}.staff-name1{color:#fff;font-family:mont-bold,sans-serif;font-size:18px;margin:4px 0}.staff-id1{color:#ffffffe6;font-family:mont-medium,sans-serif;font-size:14px}.progress-summary-container{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr 1fr;margin:0 auto;max-width:1200px;padding:16px}.progress-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;justify-content:space-between;padding:20px}.progress-text-container{margin-bottom:16px}.progress-title{color:#666;font-family:mont-medium,sans-serif;font-size:14px;margin-bottom:8px}.progress-percentage{font-family:mont-bold,sans-serif;font-size:24px;font-weight:700;margin-bottom:4px}.progress-subtitle{color:#888;font-family:mont-medium,sans-serif;font-size:14px}.progress-bar{background-color:#e0e0e0;border-radius:3px;height:6px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .3s ease}.overall-progress .progress-percentage{color:#007aff}.core-progress .progress-percentage{color:#4caf50}.elective-progress .progress-percentage{color:#ff9800}.main-content{margin:0 auto;max-width:1200px;padding:16px}.section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;padding:20px}.section-title{font-size:18px;margin-bottom:8px}.section-subtitle{font-family:mont-medium,sans-serif;margin-bottom:16px}.model-section{border:1px solid #e0e0e0;border-radius:8px;margin-bottom:16px;overflow:hidden}.section-header{align-items:center;background-color:#f9f9f9;cursor:pointer;display:flex;justify-content:space-between;padding:16px;transition:background-color .2s ease}.section-header:hover{background-color:#f0f0f0}.section-title-container{flex:1 1}.section-title{color:#333;font-family:mont-bold,sans-serif;font-size:16px;margin-bottom:4px}.section-subtitle{color:#666;font-size:14px;margin-bottom:0}.section-right{align-items:center;display:flex;gap:12px}.section-percentage{color:#007aff;font-family:mont-bold,sans-serif;font-size:16px;font-weight:700}.section-arrow{color:#666;font-size:12px}.content-list{padding:16px}.content-item{background-color:#fafafa;border:1px solid #f0f0f0;border-radius:8px;margin-bottom:12px;padding:16px}.content-header{align-items:flex-start;display:flex;gap:12px;margin-bottom:12px}.status-indicator{border-radius:50%;flex-shrink:0;height:8px;margin-top:6px;width:8px}.content-title{color:#333;font-family:mont-semibold,sans-serif;font-size:15px;line-height:1.4;margin:0}.content-details{align-items:center;display:flex;justify-content:space-between}.status-badge{border-radius:12px;color:#fff;font-family:mont-semibold,sans-serif;font-size:12px;font-weight:600;padding:4px 8px}.date-text{color:#888;font-family:mont-medium,sans-serif;font-size:12px}@media (max-width:768px){.progress-summary-container{gap:12px;grid-template-columns:1fr}.progress-container{padding:16px}.main-content{padding:12px}.section{padding:16px}}.center-container{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:50vh;padding:20px;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#007aff;height:40px;margin-bottom:16px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-text{color:#666;font-family:mont-medium,sans-serif;font-size:16px}.error-icon,.no-data-icon{font-size:48px;margin-bottom:16px}.error-text,.no-data-text{color:#666;font-family:mont-medium,sans-serif;font-size:16px;margin-bottom:20px}.retry-button{background-color:#007aff;border:none;border-radius:8px;color:#fff;cursor:pointer;font-family:mont-semibold,sans-serif;font-size:14px;padding:12px 24px;transition:background-color .2s ease}.retry-button:hover{background-color:#0056cc}
/*# sourceMappingURL=main.2f4ca028.css.map*/