.auth-container{display:flex;min-height:100vh;width:100%;font-family:DM Sans,sans-serif}.auth-left{flex:1;background-size:cover;background-position:center;background-repeat:no-repeat;display:flex;align-items:center;justify-content:center;color:#fff7e7;padding:40px}.auth-branding h2{font-family:Archivo Black,sans-serif;font-size:4rem;margin-bottom:24px;color:#fff7e7}.auth-branding p{font-family:Roboto,sans-serif;font-size:1.25rem;max-width:400px;line-height:1.6;color:#fff7e7;opacity:.9}.auth-right{flex:1;background-color:#fff7e7;display:flex;align-items:center;justify-content:center;padding:40px}.cl-eco-primary-btn{background-color:#bd4339!important;font-family:DM Sans,sans-serif!important;text-transform:uppercase;letter-spacing:.5px;border-radius:8px!important}.cl-eco-primary-btn:hover{background-color:#a33930!important}.cl-eco-auth-card{box-shadow:0 10px 40px #112f4e1a!important;border-radius:16px!important;border:1px solid rgba(17,47,78,.05)!important}.cl-eco-auth-title{font-family:Playfair Display,serif!important;color:#112f4e!important;font-size:1.75rem!important}.cl-eco-auth-subtitle{font-family:DM Sans,sans-serif!important;color:#ba9d83!important}@media(max-width:768px){.auth-container{flex-direction:column;min-height:auto}.auth-left{padding:40px 20px;text-align:center;flex:none;min-height:200px}.auth-right{padding:24px 16px;flex:none;min-height:calc(100vh - 200px)}.auth-branding h2{font-size:2.5rem;margin-bottom:14px}.auth-branding p{font-size:1rem;line-height:1.4}}@media(max-width:480px){.auth-branding h2{font-size:2rem}.auth-branding p{font-size:.92rem}.auth-left{padding:32px 16px;min-height:160px}.auth-right{padding:20px 12px}.cl-eco-auth-title{font-size:1.4rem!important}}.pending-container{min-height:100vh;width:100%;display:flex;align-items:center;justify-content:center;background-image:url(/elearning-app/dist/images/auth-bg.png);background-size:cover;background-position:center;background-repeat:no-repeat;padding:20px;box-sizing:border-box}.pending-card{background:#fff7e7f2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.5);border-radius:24px;padding:48px 40px;max-width:480px;width:100%;text-align:center;color:#112f4e;box-shadow:0 20px 40px #0006}.pending-icon{font-size:64px;margin-bottom:24px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.pending-card h1{font-size:1.6rem;font-weight:700;margin-bottom:16px;color:#bd4339;font-family:Archivo Black,sans-serif;text-transform:uppercase}.pending-card p{color:#112f4e;line-height:1.7;margin-bottom:16px;font-family:Roboto,sans-serif}.pending-hint{font-size:.85rem;color:#112f4e99!important;font-style:auto;font-weight:500;margin-bottom:32px!important}.eco-secondary-btn{background-color:transparent;border:2px solid #BD4339;color:#bd4339;padding:12px 24px;border-radius:8px;font-weight:700;cursor:pointer;font-family:Roboto,sans-serif;text-transform:uppercase;transition:all .3s}.eco-secondary-btn:hover{background-color:#bd4339;color:#fff7e7}@media(max-width:600px){.pending-container{padding:16px}.pending-card{padding:32px 20px;border-radius:16px}.pending-icon{font-size:48px;margin-bottom:16px}.pending-card h1{font-size:1.3rem}.pending-card p{font-size:.92rem;line-height:1.6}}.dashboard-home{max-width:1000px;margin:0 auto}.dashboard-loading{display:flex;justify-content:center;align-items:center;height:50vh;font-size:1.5rem;color:#112f4e}.page-title{font-family:Playfair Display,serif;color:#112f4e;font-size:2.5rem;margin:0}.page-subtitle{color:#666;font-size:1.1rem;margin-top:8px;margin-bottom:32px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:24px;margin-bottom:40px}.stat-card{background:#fff;border-radius:12px;padding:24px;display:flex;align-items:center;box-shadow:0 4px 12px #112f4e0d;border:1px solid rgba(17,47,78,.05)}.stat-icon{font-size:2.5rem;margin-right:16px;background-color:#112f4e0d;padding:12px;border-radius:50%}.stat-attendance .stat-icon{background-color:#bd43391a}.stat-content h3{margin:0;font-size:.9rem;color:#666;text-transform:uppercase;letter-spacing:.5px}.stat-content p{margin:4px 0 0;font-size:1.8rem;font-weight:700;color:#112f4e}.resume-section h2{font-family:GIAZA,serif;font-size:2rem;color:#112f4e;margin-bottom:24px}.resume-card{background:#fff;border-radius:12px;padding:24px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 12px #112f4e0d;border:1px solid rgba(17,47,78,.05)}.module-badge{background-color:#112f4e;color:#fafaee;padding:4px 12px;border-radius:20px;font-size:.8rem;font-weight:600;display:inline-block;margin-bottom:12px}.resume-info h3{margin:0 0 6px;font-size:1.4rem;color:#112f4e}.resume-module-name{margin:0;font-size:.88rem;color:#888}.progress-bar-container{width:100%;max-width:400px;height:8px;background-color:#f0f0f0;border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background-color:#bd4339;border-radius:4px;transition:width .3s ease}.progress-text{font-size:.85rem;color:#666}.empty-state{text-align:center;padding:40px;background:#fff;border-radius:12px;border:1px dashed #ccc;color:#666}.empty-state p{margin-bottom:16px}.eco-primary-btn{background-color:#bd4339;color:#fff;text-decoration:none;padding:12px 24px;border-radius:8px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;display:inline-block;transition:background-color .2s;border:none;cursor:pointer}.eco-primary-btn:hover{background-color:#a33930}@media(max-width:768px){.page-title{font-size:1.6rem;line-height:1.2}.page-subtitle{font-size:.92rem;margin-bottom:24px}.stats-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px}.stat-card{padding:14px}.stat-icon{font-size:1.6rem;padding:8px;margin-right:10px}.stat-content h3{font-size:.72rem}.stat-content p{font-size:1.3rem}.resume-card{flex-direction:column;align-items:flex-start;gap:14px;padding:18px}.resume-info h3{font-size:1.15rem}.resume-section h2{font-size:1.4rem;margin-bottom:18px}.eco-primary-btn{width:100%;text-align:center}}@media(max-width:480px){.page-title{font-size:1.4rem}.stats-grid{grid-template-columns:1fr}.stat-card{padding:16px}}.modules-page{max-width:1000px;margin:0 auto}.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:32px;margin-top:40px}.module-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px #112f4e0d;border:1px solid rgba(17,47,78,.05);display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease}.module-card:hover:not(.locked){transform:translateY(-4px);box-shadow:0 8px 24px #112f4e1a}.module-card.locked{opacity:.7}.module-image-container{height:180px;position:relative;background-color:#112f4e}.module-cover{width:100%;height:100%;object-fit:cover}.module-cover-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:GIAZA,serif;font-size:3rem;color:#fafaee;opacity:.5}.locked-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#112f4e99;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.locked-overlay span{background:#fafaee;color:#112f4e;padding:8px 16px;border-radius:20px;font-weight:600;font-size:.9rem}.completed-badge{position:absolute;top:16px;right:16px;background:#4caf50;color:#fff;padding:4px 12px;border-radius:20px;font-weight:600;font-size:.8rem}.module-content{padding:24px;display:flex;flex-direction:column;flex-grow:1}.module-number{color:#ba9d83;font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.module-title{font-family:Playfair Display,serif;font-size:1.4rem;color:#112f4e;margin:0 0 12px}.module-desc{color:#666;font-size:.95rem;line-height:1.5;margin:0 0 24px;flex-grow:1}.module-progress{display:flex;align-items:center;gap:12px;margin-bottom:24px}.module-progress span{font-size:.85rem;font-weight:600;color:#112f4e}.module-btn{text-align:center;width:100%}.eco-secondary-btn{background-color:#f5f5f5;color:#999;border:1px solid #ddd;padding:12px 24px;border-radius:8px;font-family:DM Sans,sans-serif;font-weight:600;width:100%;cursor:not-allowed;text-transform:uppercase;letter-spacing:.5px}@media(max-width:768px){.modules-grid{grid-template-columns:1fr;gap:20px;margin-top:24px}.module-image-container{height:150px}.module-content{padding:18px}.module-title{font-size:1.2rem}}@media(max-width:480px){.module-image-container{height:130px}}.assignments-tab{font-family:DM Sans,sans-serif;color:#444}.task-desc{background:#fdfdfd;padding:16px;border-radius:8px;border-left:4px solid #112F4E;margin-bottom:24px;color:#333}.eco-quill{background:#fff;border-radius:8px;margin-bottom:24px}.eco-quill .ql-editor{min-height:200px;font-family:DM Sans,sans-serif;font-size:1rem}.assignment-actions{display:flex;align-items:center;gap:16px}.status-badge{background:#fff3cd;color:#856404;padding:6px 12px;border-radius:20px;font-weight:600;font-size:.85rem}.graded-notice{background:#fff;border:1px solid rgba(17,47,78,.1);border-radius:12px;padding:24px}.grade-badge{display:inline-block;font-weight:700;font-size:1.1rem;padding:8px 16px;border-radius:6px;margin-bottom:16px;background:#f0f0f0}.feedback-box{background:#bd43390d;border-left:4px solid #BD4339;padding:16px;border-radius:0 8px 8px 0;margin-bottom:24px}.feedback-box h4{margin:0 0 8px;color:#112f4e}.readonly-content{opacity:.8;padding:16px;background:#fdfdfd;border:1px solid #eee;border-radius:8px}@media(max-width:768px){.task-desc{padding:12px;font-size:.9rem;margin-bottom:18px}.eco-quill .ql-editor{min-height:160px;font-size:.95rem}.assignment-actions{flex-wrap:wrap;gap:10px}.assignment-actions .eco-primary-btn{width:100%}.status-badge{font-size:.8rem}.graded-notice{padding:16px}.grade-badge{font-size:1rem;padding:6px 12px}.feedback-box{padding:14px}.readonly-content{padding:12px;font-size:.9rem}.eco-quill .ql-toolbar{flex-wrap:wrap}}.quiz-tab{font-family:DM Sans,sans-serif;color:#444}.quiz-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.quiz-header h3{margin:0;font-family:Playfair Display,serif;color:#112f4e;font-size:1.4rem}.quiz-score-badge{background:#112f4e;color:#fafaee;padding:6px 12px;border-radius:20px;font-weight:600;font-size:.9rem}.quiz-question-card{background:#fff;border:1px solid rgba(17,47,78,.05);box-shadow:0 4px 12px #112f4e05;border-radius:12px;padding:24px;margin-bottom:24px}.quiz-question-card h4{margin:0 0 16px;color:#112f4e;font-size:1.1rem}.quiz-options{display:flex;flex-direction:column;gap:12px}.quiz-option{display:flex;align-items:center;justify-content:space-between;width:100%;background:#fdfdfd;border:1px solid #eee;padding:16px;border-radius:8px;text-align:left;font-family:DM Sans,sans-serif;font-size:1rem;color:#444;cursor:pointer;transition:all .2s}.quiz-option:hover:not(:disabled){border-color:#bd4339;background:#bd433905}.quiz-option.selected{border-color:#bd4339;background:#bd43390d;font-weight:600}.option-content{display:flex;align-items:center;gap:12px}.radio-circle{width:20px;height:20px;border-radius:50%;border:2px solid #ccc;display:flex;align-items:center;justify-content:center}.quiz-option.selected .radio-circle,.quiz-option.correct-selected .radio-circle,.quiz-option.wrong-selected .radio-circle{border-color:#bd4339}.radio-fill{width:10px;height:10px;border-radius:50%;background:#bd4339}.quiz-option:disabled{cursor:default}.quiz-option.correct-selected{background:#d4edda;border-color:#c3e6cb;color:#155724;font-weight:600}.quiz-option.correct-revealed{border:2px dashed #4CAF50}.quiz-option.wrong-selected{background:#f8d7da;border-color:#f5c6cb;color:#721c24;font-weight:600}.result-icon{font-size:1.2rem}@media(max-width:768px){.quiz-header{flex-wrap:wrap;gap:10px;margin-bottom:18px}.quiz-header h3{font-size:1.1rem}.quiz-score-badge{font-size:.82rem;padding:5px 10px}.quiz-question-card{padding:16px;margin-bottom:14px;border-radius:10px}.quiz-question-card h4{font-size:1rem;margin-bottom:12px}.quiz-option{padding:14px 12px;min-height:48px;font-size:.92rem;gap:8px}.option-content{gap:10px}.radio-circle{width:24px;height:24px;flex-shrink:0}.radio-fill{width:12px;height:12px}}.lesson-view{display:flex;flex-direction:column;height:calc(100vh - 134px);max-width:1200px;margin:0 auto}.lesson-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.back-btn{background:transparent;border:none;font-family:DM Sans,sans-serif;color:#666;font-weight:600;cursor:pointer;padding:8px 16px;border-radius:8px;transition:all .2s}.back-btn:hover{background:#112f4e0d;color:#112f4e}.lesson-content-layout{display:flex;gap:32px;flex-grow:1;min-height:0}.lesson-main{flex:2;display:flex;flex-direction:column;overflow-y:auto;padding-right:16px}.lesson-title{font-family:Playfair Display,serif;font-size:2.2rem;color:#112f4e;margin:0 0 24px}.video-container{position:relative;width:100%;aspect-ratio:16 / 9;background-color:#112f4e;border-radius:12px;overflow:hidden;margin-bottom:24px;flex-shrink:0}.video-container iframe{width:100%;height:100%;border:none}.no-video{display:flex;align-items:center;justify-content:center;height:100%;color:#fafaee80;font-family:DM Sans,sans-serif}.lesson-description{font-family:DM Sans,sans-serif;color:#444;line-height:1.6;font-size:1.05rem}.lesson-sidebar{flex:1;background:#fff;border-radius:12px;border:1px solid rgba(17,47,78,.05);box-shadow:0 4px 12px #112f4e0d;display:flex;flex-direction:column;overflow:hidden}.tabs-header{display:flex;border-bottom:1px solid rgba(17,47,78,.1);background:#fdfdfd}.tab-btn{flex:1;background:transparent;border:none;padding:16px;font-family:DM Sans,sans-serif;font-weight:600;color:#666;cursor:pointer;border-bottom:3px solid transparent;transition:all .2s}.tab-btn:hover{background:#112f4e05;color:#112f4e}.tab-btn.active{color:#bd4339;border-bottom-color:#bd4339}.tab-content{padding:24px;flex-grow:1;overflow-y:auto}.tab-content h3{font-family:Playfair Display,serif;color:#112f4e;margin:0 0 20px;font-size:1.6rem;font-weight:700}.resources-list{list-style:none;padding:0;margin:0}.resources-list li{margin-bottom:12px}.resources-list a{display:flex;align-items:center;padding:16px 20px;background:#fff;border:1px solid rgba(17,47,78,.1);border-radius:12px;text-decoration:none;color:#112f4e;font-weight:600;font-family:DM Sans,sans-serif;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #00000005}.resources-list a:hover{background:#f4f6f9;border-color:#bd4339;color:#bd4339;transform:translateY(-2px);box-shadow:0 6px 12px #bd433914}.placeholder-box{padding:32px;text-align:center;border:1px dashed #ccc;border-radius:8px;color:#999}@media(max-width:1024px){.lesson-content-layout{flex-direction:column;overflow-y:auto}.lesson-main,.lesson-sidebar{flex:none;overflow-y:visible}}@media(max-width:768px){.lesson-view{height:auto;min-height:0;max-width:100%}.lesson-title{font-size:1.3rem;margin-bottom:14px;line-height:1.3}.lesson-header{margin-bottom:14px}.back-btn{padding:6px 10px;font-size:.9rem}.lesson-content-layout{gap:16px}.lesson-main{padding-right:0}.video-container{margin-bottom:16px;border-radius:8px}.lesson-description{font-size:.95rem}.tab-content{padding:14px}.tab-content h3{font-size:1.1rem;margin-bottom:14px}.tab-btn{padding:12px 4px;font-size:.8rem}.resources-list a{padding:12px 14px;font-size:.9rem}}.achievements-page{max-width:900px;margin:0 auto}.achievements-summary{display:flex;gap:16px;margin-bottom:40px}.summary-pill{display:flex;align-items:center;gap:10px;background-color:#112f4e;color:#fafaee;padding:14px 24px;border-radius:50px}.summary-pill--locked{background-color:#112f4e1f;color:#112f4e}.pill-num{font-size:1.6rem;font-weight:700;font-family:Playfair Display,serif}.pill-label{font-size:.85rem;font-weight:500;opacity:.8}.achievements-section{margin-bottom:40px}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}.achievement-card{display:flex;align-items:center;gap:16px;padding:18px 20px;border-radius:12px;position:relative;transition:transform .2s ease,box-shadow .2s ease}.achievement-card--unlocked{background:#fff;border:1px solid rgba(17,47,78,.08);box-shadow:0 4px 12px #112f4e0f}.achievement-card--unlocked:hover{transform:translateY(-2px);box-shadow:0 8px 20px #112f4e1a}.achievement-card--locked{background:#112f4e0a;border:1px dashed rgba(17,47,78,.15);opacity:.65}.achievement-icon{font-size:2.2rem;width:52px;height:52px;display:flex;align-items:center;justify-content:center;background-color:#bd43391a;border-radius:50%;flex-shrink:0}.achievement-icon--locked{background-color:#112f4e12;font-size:1.4rem}.achievement-info{flex:1;min-width:0}.achievement-info h3{margin:0 0 4px;font-size:.95rem;font-weight:700;color:#112f4e}.achievement-info p{margin:0;font-size:.82rem;color:#666;line-height:1.4}.achievement-check{width:26px;height:26px;border-radius:50%;background-color:#bd4339;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;flex-shrink:0}.summary-pill--total{background-color:#112f4e0f;color:#112f4e}.achievements-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid rgba(17,47,78,.1)}.cat-progress{font-size:.82rem;font-weight:700;color:#bd4339;background:#bd433914;padding:4px 12px;border-radius:20px}@media(max-width:600px){.achievements-summary{flex-wrap:wrap;gap:10px}.summary-pill{padding:10px 16px}.pill-num{font-size:1.2rem}.achievements-grid{grid-template-columns:1fr}.achievement-card{padding:14px 16px}.achievement-icon{width:42px;height:42px;font-size:1.6rem}}.notifications-page{max-width:750px;margin:0 auto}.notif-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px;gap:16px}.mark-all-btn{flex-shrink:0;background:none;border:1px solid #BD4339;color:#bd4339;padding:8px 16px;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;margin-top:6px}.mark-all-btn:hover{background-color:#bd4339;color:#fff}.notif-list{display:flex;flex-direction:column;gap:12px}.notif-item{display:flex;align-items:flex-start;gap:16px;padding:18px 20px;background:#fff;border-radius:12px;border:1px solid rgba(17,47,78,.07);box-shadow:0 2px 8px #112f4e0a;cursor:pointer;transition:box-shadow .2s,transform .2s;position:relative}.notif-item--unread{border-color:#bd433933;background:#fffaf9}.notif-item--clickable{cursor:pointer}.notif-item:not(.notif-item--clickable){cursor:default}.notif-item:hover{box-shadow:0 6px 18px #112f4e1a;transform:translateY(-1px)}.notif-item--clickable:hover{border-color:#bd433959;background:#fff8f7}.notif-arrow{font-size:1.5rem;color:#bd4339;font-weight:300;flex-shrink:0;align-self:center;opacity:.7}.notif-icon-wrap{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-type-icon{font-size:1.4rem}.notif-body{flex:1;min-width:0}.notif-type-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.notif-title{margin:4px 0;font-size:.97rem;font-weight:600;color:#112f4e;line-height:1.4}.notif-message{margin:0 0 6px;font-size:.85rem;color:#555;line-height:1.5}.notif-time{font-size:.78rem;color:#999}.notif-dot{width:10px;height:10px;border-radius:50%;background-color:#bd4339;flex-shrink:0;margin-top:6px}.notif-empty{text-align:center;padding:60px 20px;background:#fff;border-radius:16px;border:1px dashed rgba(17,47,78,.15);color:#666}.notif-empty-icon{font-size:3rem;display:block;margin-bottom:16px}.notif-empty p{margin:0 0 8px;font-size:1rem;font-weight:600;color:#112f4e}.notif-empty-sub{font-size:.88rem!important;font-weight:400!important;color:#888!important;max-width:400px;margin:0 auto!important;line-height:1.5}@media(max-width:600px){.notif-header{flex-direction:column;gap:12px}.notif-item{padding:14px;gap:10px}.notif-icon-wrap{width:38px;height:38px}.notif-type-icon{font-size:1.1rem}.notif-title{font-size:.9rem}.notif-message{font-size:.82rem}}.attendance-page{max-width:800px;margin:0 auto}.att-stats-row{margin-bottom:40px}.att-stat-card--main{background:#fff;border-radius:16px;padding:32px;display:flex;align-items:center;gap:40px;box-shadow:0 4px 16px #112f4e12;border:1px solid rgba(17,47,78,.07)}.att-percentage-ring{position:relative;width:130px;height:130px;flex-shrink:0}.att-percentage-ring svg{width:130px;height:130px}.ring-bg{fill:none;stroke:#112f4e14;stroke-width:12}.ring-fill{fill:none;stroke:#bd4339;stroke-width:12;stroke-linecap:round;transition:stroke-dasharray .6s ease}.att-percentage-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.att-pct-num{display:block;font-size:1.7rem;font-weight:700;color:#112f4e;font-family:Playfair Display,serif;line-height:1}.att-pct-sub{display:block;font-size:.72rem;color:#888;margin-top:2px}.att-totals{flex:1}.att-total-row{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:.92rem;color:#333}.att-total-row span:not(.att-dot){flex:1}.att-total-row strong{font-size:1.1rem;color:#112f4e;min-width:28px;text-align:right}.att-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.att-dot--present{background-color:#2e7d32}.att-dot--absent{background-color:#bd4339}.att-dot--excused{background-color:#f59e0b}.att-total-divider{height:1px;background-color:#112f4e14;margin:8px 0}.att-month-section{margin-bottom:32px}.section-heading{font-family:Playfair Display,serif;font-size:1.4rem;color:#112f4e;margin:0 0 20px;padding-bottom:10px;border-bottom:2px solid rgba(17,47,78,.1)}.att-month-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}.att-month-tab{padding:7px 16px;border-radius:20px;border:1px solid rgba(17,47,78,.2);background:#fff;color:#112f4e;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s}.att-month-tab:hover{border-color:#bd4339;color:#bd4339}.att-month-tab--active{background-color:#112f4e;color:#fafaee;border-color:#112f4e}.att-records-list{display:flex;flex-direction:column;gap:10px}.att-record-item{display:flex;align-items:center;gap:16px;padding:14px 20px;background:#fff;border-radius:10px;border-left:4px solid transparent;box-shadow:0 2px 6px #112f4e0a}.att-present{border-left-color:#2e7d32}.att-absent{border-left-color:#bd4339}.att-excused{border-left-color:#f59e0b}.att-record-date{min-width:110px;display:flex;flex-direction:column}.att-record-day{font-size:.75rem;text-transform:uppercase;color:#999;letter-spacing:.5px}.att-record-num{font-size:.95rem;font-weight:600;color:#112f4e}.att-record-status{font-size:.8rem;font-weight:700;padding:4px 12px;border-radius:20px;text-transform:uppercase;letter-spacing:.3px}.att-badge--present{background-color:#e8f5e9;color:#2e7d32}.att-badge--absent{background-color:#feeceb;color:#bd4339}.att-badge--excused{background-color:#fef3c7;color:#b45309}.att-record-notes{flex:1;font-size:.83rem;color:#666;font-style:italic}.att-empty{text-align:center;padding:40px;background:#fff;border-radius:12px;border:1px dashed rgba(17,47,78,.15);color:#888}@media(max-width:600px){.att-stat-card--main{flex-direction:column;align-items:center;text-align:center;padding:24px;gap:24px}.att-total-row span:not(.att-dot){text-align:left}.att-percentage-ring,.att-percentage-ring svg{width:100px;height:100px}.att-pct-num{font-size:1.3rem}.att-record-item{flex-wrap:wrap;gap:8px;padding:12px 14px}.att-record-date{min-width:auto}.section-heading{font-size:1.2rem}}.layout{display:flex;height:100vh;width:100%;font-family:DM Sans,sans-serif;background-color:#fafaee;overflow:hidden}.student-loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.5rem;color:#112f4e}.sidebar{width:260px;min-width:260px;background-color:#112f4e;color:#fafaee;display:flex;flex-direction:column;padding:24px;overflow-y:auto}.logo-container{display:flex;justify-content:center;margin-bottom:30px}.logo{max-width:120px;height:auto}.user-profile{text-align:center;margin-bottom:30px}.avatar img{width:80px;height:80px;border-radius:50%;border:2px solid #BD4339;object-fit:cover;margin-bottom:12px}.user-name{font-weight:700;font-size:1.1rem;margin:0 0 8px;font-family:Playfair Display,serif}.user-name-row{display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:8px}.user-name-row .user-name{margin:0}.edit-name-btn{background:none;border:none;color:#fafaee80;cursor:pointer;font-size:.9rem;padding:4px;border-radius:4px;transition:color .2s;line-height:1}.edit-name-btn:hover{color:#fafaee}.edit-name-container{margin-bottom:8px}.edit-name-input{width:100%;padding:8px 10px;border:1px solid rgba(250,250,238,.3);border-radius:6px;background:#ffffff1a;color:#fafaee;font-family:DM Sans,sans-serif;font-size:.9rem;text-align:center;outline:none;box-sizing:border-box}.edit-name-input:focus{border-color:#bd4339}.edit-name-input::placeholder{color:#fafaee66}.edit-name-actions{display:flex;gap:6px;margin-top:6px;justify-content:center}.edit-name-save,.edit-name-cancel{padding:4px 12px;border-radius:6px;font-size:.78rem;font-weight:600;cursor:pointer;border:none;font-family:DM Sans,sans-serif;transition:opacity .2s}.edit-name-save{background:#bd4339;color:#fff}.edit-name-save:disabled{opacity:.6;cursor:not-allowed}.edit-name-cancel{background:#ffffff26;color:#fafaee}.edit-name-cancel:hover{background:#ffffff40}.user-stats{display:flex;justify-content:center;gap:12px;font-size:.85rem;background-color:#ffffff1a;padding:8px;border-radius:8px;color:#ba9d83}.nav-links{list-style:none;padding:0;margin:0;flex-grow:1}.nav-links li{margin-bottom:12px}.nav-links a{display:flex;align-items:center;gap:10px;text-decoration:none;color:#fafaee;padding:12px 16px;border-radius:8px;transition:all .2s ease;font-weight:500;position:relative}.nav-links a:hover{background-color:#ffffff1a}.nav-links a.nav-active{background-color:#bd4339;color:#fafaee}.nav-icon{font-size:1rem;flex-shrink:0}.notif-badge{position:absolute;right:12px;top:50%;transform:translateY(-50%);background-color:#bd4339;color:#fff;font-size:.7rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}.nav-links a.nav-active .notif-badge{background-color:#fff;color:#bd4339}.nav-bottom{margin-top:auto;display:flex;flex-direction:column;gap:12px}.admin-link,.logout-btn{width:100%;padding:12px;border-radius:8px;border:none;font-family:DM Sans,sans-serif;font-weight:600;cursor:pointer;text-align:center;transition:all .2s ease;text-decoration:none}.admin-link{background-color:#fafaee;color:#112f4e}.admin-link:hover{background-color:#e0e0d5}.logout-btn{background-color:transparent;color:#bd4339;border:1px solid #BD4339}.logout-btn:hover{background-color:#bd4339;color:#fafaee}.main-content{flex-grow:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{height:56px;background-color:#fff;border-bottom:1px solid rgba(17,47,78,.08);display:flex;align-items:center;justify-content:flex-end;padding:0 28px;flex-shrink:0}.topbar-right{position:relative}.hamburger-btn{display:none;background:none;border:none;cursor:pointer;padding:8px;margin-right:auto;flex-direction:column;gap:5px}.hamburger-line{display:block;width:22px;height:2px;background-color:#112f4e;border-radius:2px;transition:transform .2s}.sidebar-overlay{display:none}.bell-btn{position:relative;background:none;border:none;font-size:1.3rem;cursor:pointer;padding:6px 8px;border-radius:8px;transition:background .2s;line-height:1}.bell-btn:hover{background:#112f4e0f}.bell-badge{position:absolute;top:0;right:0;background-color:#bd4339;color:#fff;font-size:.62rem;font-weight:700;min-width:17px;height:17px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid white}.bell-popup{position:absolute;top:calc(100% + 10px);right:0;width:320px;background:#fff;border-radius:14px;box-shadow:0 12px 40px #112f4e26;border:1px solid rgba(17,47,78,.08);z-index:999;overflow:hidden;animation:popIn .15s ease}@keyframes popIn{0%{opacity:0;transform:translateY(-6px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.bell-popup-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 12px;border-bottom:1px solid rgba(17,47,78,.07);font-weight:700;font-size:.92rem;color:#112f4e}.bell-popup-count{background:#bd43391a;color:#bd4339;font-size:.75rem;padding:2px 8px;border-radius:10px;font-weight:700}.bell-popup-body{max-height:240px;overflow-y:auto}.bell-popup-empty{text-align:center;color:#999;padding:24px 16px;font-size:.88rem;margin:0}.bell-popup-item{display:flex;align-items:flex-start;gap:12px;padding:12px 18px;border-bottom:1px solid rgba(17,47,78,.05);cursor:default}.bell-popup-item:last-child{border-bottom:none}.bell-item-icon{font-size:1.3rem;flex-shrink:0;margin-top:1px}.bell-item-body{flex:1;min-width:0}.bell-item-title{margin:0 0 3px;font-size:.85rem;font-weight:600;color:#112f4e;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bell-item-time{font-size:.76rem;color:#aaa}.bell-popup-footer{display:block;width:100%;padding:12px;text-align:center;background:#112f4e08;border:none;border-top:1px solid rgba(17,47,78,.07);color:#bd4339;font-size:.85rem;font-weight:600;cursor:pointer;transition:background .2s}.bell-popup-footer:hover{background:#112f4e12}.content-container{flex-grow:1;padding:32px;overflow-y:auto;-webkit-overflow-scrolling:touch}@media(max-width:768px){.sidebar{position:fixed;top:0;left:0;height:100vh;z-index:1000;transform:translate(-100%);transition:transform .3s ease}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;inset:0;background:#0006;z-index:999}.hamburger-btn{display:flex}.topbar{padding:0 16px;gap:8px}.content-container{padding:20px 16px}.bell-popup{width:min(320px,calc(100vw - 32px));right:-8px}}.admin-layout{background-color:#f4f6f9}.admin-sidebar{background-color:#112f4e}.admin-badge{background-color:#bd4339;color:#fff;padding:3px 12px;border-radius:20px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.admin-topbar{height:56px;background:#fff;border-bottom:1px solid rgba(17,47,78,.08);display:flex;align-items:center;padding:0 32px;flex-shrink:0}.admin-topbar-brand{display:flex;align-items:baseline;gap:10px}.admin-topbar-title{font-family:Playfair Display,serif;font-size:1.2rem;font-weight:700;color:#112f4e}.admin-topbar-sub{font-size:.78rem;color:#bd4339;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.student-link{display:block;width:100%;padding:10px 12px;border-radius:8px;font-family:DM Sans,sans-serif;font-weight:600;font-size:.88rem;text-align:center;text-decoration:none;background-color:#ffffff1a;color:#fafaee;transition:background .2s;box-sizing:border-box}.student-link:hover{background-color:#fff3;color:#fafaee}.admin-content{background:transparent}.admin-page-title{font-family:Playfair Display,serif;color:#112f4e;font-size:2rem;margin:0 0 8px}.admin-loading{display:flex;justify-content:center;align-items:center;height:100vh;font-size:1.2rem;color:#112f4e}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:16px}.admin-empty-state{text-align:center;padding:48px;background:#fff;border-radius:12px;border:1px dashed rgba(17,47,78,.15);color:#888}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;margin-bottom:40px}.admin-stat-card{background:#fff;border-radius:12px;padding:20px 24px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #112f4e0f;border:1px solid rgba(17,47,78,.06)}.admin-stat-card.highlight{border-left:4px solid #BD4339}.admin-stat-card .stat-icon{font-size:2rem;background:#112f4e0f;padding:10px;border-radius:50%}.admin-stat-card .stat-content h3{margin:0;font-size:.8rem;color:#888;text-transform:uppercase;letter-spacing:.4px}.admin-stat-card .stat-content p{margin:4px 0 0;font-size:1.8rem;font-weight:700;color:#112f4e;font-family:Playfair Display,serif}.admin-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #112f4e0f;border:1px solid rgba(17,47,78,.06)}.admin-table{width:100%;border-collapse:collapse}.admin-table th{text-align:left;padding:14px 20px;font-size:.78rem;font-weight:700;color:#888;text-transform:uppercase;letter-spacing:.5px;background:#fafaee;border-bottom:1px solid rgba(17,47,78,.08)}.admin-table td{padding:14px 20px;border-bottom:1px solid rgba(17,47,78,.05);color:#333;font-size:.93rem}.admin-table tr:hover td{background:#112f4e05}.mod-label{background:#112f4e;color:#fafaee;padding:2px 8px;border-radius:10px;font-size:.75rem;font-weight:700;margin-right:8px}.admin-action-btn{display:inline-block;padding:6px 14px;background:#bd4339;color:#fff;border-radius:6px;font-size:.82rem;font-weight:600;text-decoration:none;transition:background .2s}.admin-action-btn:hover{background:#a33930;color:#fff}.admin-link-btn{padding:8px 16px;background:none;border:1px solid #112F4E;color:#112f4e;border-radius:8px;font-size:.85rem;font-weight:600;text-decoration:none;transition:all .2s}.admin-link-btn:hover{background:#112f4e;color:#fff}.eco-primary-btn{background:#bd4339;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-family:DM Sans,sans-serif;font-weight:600;cursor:pointer;text-decoration:none;display:inline-block;transition:background .2s;font-size:.9rem}.eco-primary-btn:hover{background:#a33930}.eco-primary-btn:disabled{opacity:.6;cursor:not-allowed}.eco-secondary-btn{background:transparent;color:#112f4e;border:1px solid rgba(17,47,78,.25);padding:8px 16px;border-radius:8px;font-family:DM Sans,sans-serif;font-weight:600;cursor:pointer;text-decoration:none;display:inline-block;transition:all .2s;font-size:.88rem}.eco-secondary-btn:hover{border-color:#112f4e;background:#112f4e0a}.admin-recent-section h2{font-family:Playfair Display,serif;font-size:1.4rem;color:#112f4e;margin:0}@media(max-width:768px){.admin-topbar{padding:0 16px;gap:8px}.admin-topbar-brand{gap:6px}.admin-topbar-title{font-size:1rem}.admin-page-title{font-size:1.4rem}.section-header{flex-direction:column;align-items:flex-start;gap:12px}.admin-stats-grid{grid-template-columns:1fr 1fr;gap:12px}.admin-stat-card{padding:16px;gap:10px}.admin-stat-card .stat-content p{font-size:1.4rem}.admin-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.admin-table th,.admin-table td{padding:10px 12px;font-size:.82rem;white-space:nowrap}}.admin-dashboard{max-width:1200px;margin:0 auto}.admin-page-title{font-family:Playfair Display,serif;color:#2c3e50;font-size:2.2rem;margin:0 0 32px}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:48px}.admin-stat-card{background:#fff;border-radius:12px;padding:24px;display:flex;align-items:center;box-shadow:0 2px 8px #0000000d;border:1px solid #e1e4e8}.admin-stat-card.highlight{border-left:4px solid #BD4339;background-color:#fffaf9}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.section-header h2{font-family:DM Sans,sans-serif;color:#2c3e50;font-size:1.5rem;margin:0}.admin-link-btn{color:#112f4e;font-weight:600;text-decoration:none;font-size:.95rem}.admin-link-btn:hover{text-decoration:underline}.admin-table-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000000d;border:1px solid #e1e4e8}.admin-table{width:100%;border-collapse:collapse;text-align:left}.admin-table th{background:#f8f9fa;padding:16px 24px;font-weight:600;color:#6c757d;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #e1e4e8}.admin-table td{padding:16px 24px;color:#2c3e50;border-bottom:1px solid #e1e4e8;font-size:.95rem}.admin-table tr:last-child td{border-bottom:none}.mod-label{background:#e9ecef;color:#495057;padding:2px 8px;border-radius:12px;font-size:.8rem;font-weight:600;margin-right:8px}.admin-action-btn{background:#bd4339;color:#fff;padding:6px 16px;border-radius:6px;text-decoration:none;font-size:.85rem;font-weight:600;transition:background .2s}.admin-action-btn:hover{background:#a33930}.admin-empty-state{background:#fff;padding:48px;text-align:center;border-radius:12px;border:1px dashed #ced4da;color:#6c757d}@media(max-width:768px){.admin-page-title{font-size:1.5rem;margin-bottom:20px}.admin-stats-grid{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:28px}.admin-stat-card{padding:16px;flex-direction:column;align-items:flex-start;text-align:left}.section-header{flex-direction:column;align-items:flex-start;gap:10px}.section-header h2{font-size:1.2rem}.admin-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:8px}.admin-table th,.admin-table td{padding:10px 12px;font-size:.82rem;white-space:nowrap}.admin-empty-state{padding:28px 16px}}@media(max-width:480px){.admin-stats-grid{grid-template-columns:1fr}}.approve-users{padding:24px;max-width:900px;margin:0 auto}.approve-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.approve-header h2{margin:0;font-size:1.5rem;color:var(--text-primary, #1f2937)}.pending-badge{background:#ef4444;color:#fff;border-radius:999px;padding:2px 10px;font-size:.8rem;font-weight:700;animation:pulse-red 2s infinite}@keyframes pulse-red{0%,to{opacity:1}50%{opacity:.7}}.approve-controls{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap;align-items:center}.view-tabs{display:flex;gap:4px;background:#0000000d;border-radius:10px;padding:4px}.tab-btn{padding:8px 16px;border:none;border-radius:8px;background:transparent;cursor:pointer;font-size:.9rem;transition:all .2s;color:inherit}.tab-btn.active{background:#fff;box-shadow:0 2px 8px #0000001a;font-weight:600}.search-input{flex:1;padding:10px 14px;border:1px solid rgba(0,0,0,.1);border-radius:10px;font-size:.9rem;min-width:200px;background:#fff}.loading-msg,.empty-msg{text-align:center;padding:48px;color:#6b7280;font-size:1rem}.users-list{display:flex;flex-direction:column;gap:12px}.user-card{background:#fff;border-radius:16px;box-shadow:0 2px 12px #0000000f;padding:20px;display:flex;align-items:center;justify-content:space-between;gap:16px;border-left:4px solid #e5e7eb;flex-wrap:wrap}.user-card.pending{border-left-color:#f59e0b}.user-card.approved{border-left-color:#10b981}.user-card.rejected{border-left-color:#ef4444}.user-info{display:flex;align-items:center;gap:14px;flex:1}.user-avatar{width:48px;height:48px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.2rem;flex-shrink:0}.user-details{display:flex;flex-direction:column;gap:4px}.user-details strong{font-size:1rem;color:#111827}.user-email{font-size:.85rem;color:#6b7280}.user-badges{display:flex;gap:6px;margin-top:4px;flex-wrap:wrap}.badge{font-size:.75rem;padding:3px 8px;border-radius:999px;font-weight:500}.status-badge{background:#f3f4f6;color:#374151}.role-badge{background:#ede9fe;color:#5b21b6}.user-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.approve-btn,.reject-btn,.reset-btn{padding:8px 14px;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.approve-btn{background:#10b981;color:#fff}.approve-btn:hover{background:#059669;transform:translateY(-1px)}.mentor-btn{background:#8b5cf6!important}.mentor-btn:hover{background:#7c3aed!important}.reject-btn{background:#fee2e2;color:#dc2626}.reject-btn:hover{background:#fecaca}.reset-btn{background:#f3f4f6;color:#6b7280}.role-select{padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:.85rem;cursor:pointer;background:#fff}@media(max-width:768px){.approve-users{padding:0}.approve-header{flex-wrap:wrap}.approve-header h2{font-size:1.2rem}.approve-controls{flex-direction:column;align-items:stretch;gap:10px}.view-tabs{width:100%;justify-content:center}.tab-btn{flex:1;text-align:center;padding:10px 8px;font-size:.82rem}.search-input{width:100%;min-width:0}.user-card{padding:14px;gap:10px;align-items:flex-start}.user-info{width:100%}.user-avatar{width:40px;height:40px;font-size:1rem}.user-details strong{font-size:.95rem}.user-email{font-size:.78rem;word-break:break-word}.user-actions{width:100%;gap:6px}.approve-btn,.reject-btn,.reset-btn{flex:1;padding:10px 8px;font-size:.8rem}.role-select{flex:1;min-width:120px}}.attendance-manager{padding-bottom:40px}.attendance-controls{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:24px;border-radius:12px;box-shadow:0 4px 12px #112f4e0d;margin-bottom:30px;border:1px solid rgba(17,47,78,.05)}.date-picker-group{display:flex;flex-direction:column;gap:8px}.date-picker-group label{font-weight:600;color:#112f4e;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.eco-input{padding:12px 16px;border-radius:8px;border:1px solid #ddd;font-family:DM Sans,sans-serif;color:#333;transition:all .2s;font-size:1rem}.eco-input:focus{border-color:#112f4e;outline:none;box-shadow:0 0 0 3px #112f4e1a}.attendance-table th{font-family:Playfair Display,serif;color:#112f4e;font-size:1.1rem;padding-bottom:16px;border-bottom:2px solid rgba(17,47,78,.1)}.attendance-table td{padding:16px 8px;vertical-align:middle}.notes-input{width:100%;max-width:300px;padding:8px 12px;font-size:.9rem}.custom-radio{display:block;position:relative;padding-left:25px;margin-bottom:20px;cursor:pointer;font-size:22px;-webkit-user-select:none;user-select:none;height:20px}.custom-radio input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkmark{position:absolute;top:0;left:50%;transform:translate(-50%);height:24px;width:24px;background-color:#eee;border-radius:50%;transition:all .2s}.custom-radio:hover input~.checkmark{background-color:#ccc}.custom-radio input:checked~.checkmark{background-color:#112f4e}.checkmark:after{content:"";position:absolute;display:none}.custom-radio input:checked~.checkmark:after{display:block}.custom-radio .checkmark:after{top:7px;left:7px;width:10px;height:10px;border-radius:50%;background:#fff}.present-radio input:checked~.checkmark{background-color:#2e7d32}.absent-radio input:checked~.checkmark{background-color:#bd4339}.excused-radio input:checked~.checkmark{background-color:#f57c00}.role-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.row-absent td{background-color:#bd43390a}.row-excused td{background-color:#f57c000a}.attendance-summary{display:flex;gap:8px;align-items:center}.summary-chip{display:inline-block;padding:5px 12px;border-radius:20px;font-size:.8rem;font-weight:600}.present-chip{background:#e8f5e9;color:#2e7d32}.absent-chip{background:#fdecea;color:#bd4339}.excused-chip{background:#fff3e0;color:#f57c00}.attendance-hint-box{background:#f0f7ff;border:1px solid #b3d4f5;border-radius:10px;padding:16px 24px;margin-bottom:24px;color:#1565c0;font-size:.95rem}.attendance-hint-box p{margin:0}@media(max-width:768px){.attendance-controls{flex-direction:column;gap:16px;align-items:stretch;padding:16px}.admin-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.attendance-table th,.attendance-table td{white-space:nowrap;padding:10px 8px;font-size:.85rem}.notes-input{max-width:150px}.attendance-summary{flex-wrap:wrap}}.admin-modules-list{display:flex;flex-direction:column;gap:24px}.admin-module-card{background:#fff;border-radius:12px;border:1px solid rgba(17,47,78,.05);box-shadow:0 2px 8px #0000000d;padding:24px}.mod-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.mod-card-title{display:flex;align-items:center;gap:16px}.mod-card-title h2{font-family:Playfair Display,serif;margin:0;color:#112f4e;font-size:1.6rem}.draft-badge{background:#fff3cd;color:#856404;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.mod-desc{color:#666;margin:0 0 24px;max-width:800px}.mod-lessons h4{margin:0 0 16px;font-family:DM Sans,sans-serif;color:#112f4e;border-bottom:2px solid rgba(17,47,78,.05);padding-bottom:8px}.admin-lesson-list{list-style:none;padding:0;margin:0 0 16px;display:flex;flex-direction:column;gap:8px}.admin-lesson-item{display:flex;align-items:center;background:#fdfdfd;border:1px solid #eee;padding:12px 16px;border-radius:8px}.lesson-num{font-weight:700;color:#112f4e;width:40px}.lesson-name{flex-grow:1;color:#444;font-weight:500}.icon-btn{background:transparent;border:none;color:#666;cursor:pointer;font-size:.9rem}.icon-btn:hover{color:#bd4339;text-decoration:underline}.icon-btn--danger:hover{color:#c0392b}.add-lesson-btn{background:transparent;border:1px dashed #ced4da;color:#6c757d;padding:12px;width:100%;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.add-lesson-btn:hover{border-color:#112f4e;color:#112f4e;background:#112f4e05}.empty-text{color:#999;font-style:italic}.edit-btn{padding:8px 16px;font-size:.9rem;width:auto}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#112f4e66;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;padding:32px;width:100%;max-width:500px;box-shadow:0 12px 40px #112f4e26}.modal-content h2{font-family:Playfair Display,serif;color:#112f4e;margin:0 0 24px}.mod-card-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.module-hidden{opacity:.65}.toggle-btn{padding:6px 14px;border-radius:20px;border:1px solid rgba(17,47,78,.2);background:#fff;color:#666;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s}.toggle-btn--active{background:#e8f5e9;border-color:#2e7d32;color:#2e7d32}.toggle-btn:hover{border-color:#112f4e;color:#112f4e}.delete-btn{padding:6px 14px;border-radius:8px;border:1px solid rgba(189,67,57,.3);background:#fff;color:#bd4339;font-size:.82rem;font-weight:600;cursor:pointer;transition:all .2s}.delete-btn:hover{background:#bd4339;color:#fff}.cm-error-banner{background:#feeceb;color:#bd4339;border:1px solid rgba(189,67,57,.3);border-radius:8px;padding:12px 16px;margin-bottom:20px;font-size:.9rem}.form-label{display:block;font-weight:700;margin-bottom:8px;color:#112f4e;font-size:.9rem}.form-input{width:100%;padding:10px 14px;border-radius:8px;border:1px solid rgba(17,47,78,.2);font-family:DM Sans,sans-serif;font-size:.92rem;box-sizing:border-box;transition:border-color .2s}.form-input:focus{outline:none;border-color:#112f4e}.form-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:600;color:#112f4e;font-size:.9rem}.form-toggle input[type=checkbox]{width:18px;height:18px;cursor:pointer}@media(max-width:768px){.admin-module-card{padding:16px}.mod-card-header{flex-direction:column;align-items:flex-start;gap:8px}.mod-card-actions{gap:6px}.modal-content{padding:20px;margin:16px;max-width:calc(100% - 32px)}}.assignment-grader{max-width:1200px;margin:0 auto}.status-pill{padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-pill.submitted{background:#fff3cd;color:#856404}.status-pill.graded{background:#d4edda;color:#155724}.back-link{background:transparent;border:none;font-family:DM Sans,sans-serif;color:#666;font-weight:600;cursor:pointer;padding:0}.back-link:hover{text-decoration:underline;color:#112f4e}.grader-layout{display:flex;gap:32px;margin-top:24px}.submission-content{flex:2;background:#fff;border-radius:12px;border:1px solid rgba(17,47,78,.05);box-shadow:0 4px 12px #112f4e0d;padding:32px}.submission-header{border-bottom:2px solid rgba(17,47,78,.05);padding-bottom:24px;margin-bottom:24px}.submission-header h2{font-family:Playfair Display,serif;color:#112f4e;margin:0 0 8px;font-size:1.8rem}.student-name{font-weight:600;color:#444;margin:0 0 4px;font-size:1.1rem}.submission-date{color:#999;font-size:.9rem;margin:0}.rich-text-content{font-family:DM Sans,sans-serif;color:#333;line-height:1.6}.grading-panel{flex:1;background:#fdfdfd;border-radius:12px;border:1px solid rgba(17,47,78,.1);padding:32px;height:fit-content;position:sticky;top:32px}.grading-panel h3{font-family:GIAZA,serif;color:#112f4e;margin:0 0 24px;font-size:1.5rem}.form-group{margin-bottom:24px;display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#444;font-size:.95rem}.grade-select{padding:12px 16px;border:1px solid #ced4da;border-radius:8px;font-family:DM Sans,sans-serif;font-size:1rem;width:100%}.grade-select:focus{outline:none;border-color:#112f4e}.form-group textarea{padding:16px;border:1px solid #ced4da;border-radius:8px;font-family:DM Sans,sans-serif;font-size:.95rem;resize:vertical}.form-group textarea:focus{outline:none;border-color:#112f4e}.grade-btn{width:100%;padding:16px;font-size:1.1rem}.grader-filter-bar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}.grader-stats{display:flex;align-items:center}.pending-badge-count{background:#fff3cd;color:#856404;padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:700}.filter-tabs{display:flex;gap:6px}.filter-tab{padding:7px 16px;border:1px solid #ddd;border-radius:20px;background:#fff;cursor:pointer;font-family:DM Sans,sans-serif;font-size:.85rem;color:#666;transition:all .2s}.filter-tab:hover{border-color:#112f4e;color:#112f4e}.filter-tab.active{background:#112f4e;border-color:#112f4e;color:#fff;font-weight:600}.row-pending td{background-color:#ffc1070a}.file-link{color:#112f4e;font-weight:600;text-decoration:none;font-size:.9rem}.file-link:hover{text-decoration:underline;color:#bd4339}.grade-pill{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.78rem;font-weight:700}.grade-pill.approved{background:#d4edda;color:#155724}.grade-pill.rejected{background:#fdecea;color:#bd4339}.section-header{display:flex;align-items:center;gap:20px;margin-bottom:8px}.graded-indicator{font-size:.85rem;color:#2e7d32;font-weight:600;background:#e8f5e9;padding:4px 12px;border-radius:20px}.task-description-box{background:#f8f9fa;border-left:4px solid #112F4E;border-radius:0 8px 8px 0;padding:16px 20px;margin-bottom:24px}.task-description-box h4{margin:0 0 8px;color:#112f4e;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.task-description-box p{margin:0;color:#444;line-height:1.6}.file-submission-box{background:#f0f7ff;border:1px solid #b3d4f5;border-radius:10px;padding:24px}.file-submission-box h4{margin:0 0 4px;color:#112f4e}.no-file-box{background:#fff8e1;border:1px solid #ffe082;border-radius:10px;padding:20px;color:#795548}.already-graded-info{margin-top:20px;padding:14px;background:#f8f9fa;border-radius:8px;font-size:.88rem;color:#555;border:1px solid #eee}.already-graded-info p{margin:4px 0}@media(max-width:1024px){.grader-layout{flex-direction:column;gap:20px}.grading-panel{position:static}.grader-filter-bar{flex-direction:column;align-items:flex-start}}@media(max-width:768px){.submission-content{padding:18px}.submission-header h2{font-size:1.3rem}.student-name{font-size:1rem}.grading-panel{padding:18px}.grading-panel h3{font-size:1.2rem}.form-group textarea{min-height:120px}.grade-btn{padding:14px;font-size:1rem}.task-description-box{padding:12px 14px}.file-submission-box,.no-file-box{padding:16px}.file-link{word-break:break-all}.filter-tabs{flex-wrap:wrap;gap:4px}.filter-tab{flex:1;min-width:90px;text-align:center;font-size:.78rem;padding:7px 10px}}@media(max-width:480px){.grader-filter-bar{gap:8px}.grader-filter-bar select,.grader-filter-bar input{font-size:.85rem}.already-graded-info{padding:10px;font-size:.82rem}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#112f4e;background-color:#fff7e7;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;text-size-adjust:100%}*{box-sizing:border-box}html,body{overflow-x:hidden}body{margin:0;min-width:320px;min-height:100vh;background-color:#fff7e7}#root{width:100%;height:100%;display:flex;flex-direction:column}a{font-weight:500;color:#bd4339;text-decoration:inherit}a:hover{color:#a33930}@media(max-width:768px){input,select,textarea{font-size:16px!important}button,.eco-primary-btn,.eco-secondary-btn,a.admin-link,a.student-link{min-height:40px}a,button{-webkit-tap-highlight-color:transparent;touch-action:manipulation}img{max-width:100%;height:auto}}.eco-fullscreen-loader{display:flex;justify-content:center;align-items:center;height:100vh;width:100%;background-color:#fff7e7}.eco-spinner{width:50px;height:50px;border:4px solid rgba(17,47,78,.1);border-left-color:#112f4e;border-radius:50%;animation:eco-spin 1s linear infinite}@keyframes eco-spin{to{transform:rotate(360deg)}}
