:root{--primary-soft:#7b9ebd;--primary-light:#a8c5e3;--secondary-soft:#b8a5d6;--success-soft:#88b68d;--warning-soft:#e8b68a;--danger-soft:#d99999;--bg-primary:#f5f7fa;--bg-secondary:#fff;--bg-card:#fff;--text-primary:#4a5568;--text-secondary:#718096;--text-light:#a0aec0;--border-color:#e2e8f0;--shadow-sm:0 2px 8px rgba(123,158,189,.08);--shadow-md:0 4px 16px rgba(123,158,189,.12);--shadow-lg:0 8px 24px rgba(123,158,189,.15);--spacing-xs:0.5rem;--spacing-sm:1rem;--spacing-md:1.5rem;--spacing-lg:2rem;--spacing-xl:3rem;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:linear-gradient(135deg,#f5f7fa,#e8eef5);color:var(--text-primary);line-height:1.6;min-height:100vh}body.teacher-dashboard,body.teacher-page,body:has(.chat-container),body:has(.student-dashboard-container),body:has(.student-list-container){overflow-x:hidden}.lang-switcher{display:inline-flex;align-items:center;gap:0;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:.25rem;box-shadow:var(--shadow-sm)}.lang-btn{padding:.45rem 1rem;border:none;border-radius:calc(var(--radius-xl) - 3px);font-size:.875rem;font-weight:500;cursor:pointer;color:var(--text-secondary);background:transparent;transition:all .25s ease}.lang-btn:hover{color:var(--primary-soft);background:linear-gradient(90deg,rgba(123,158,189,.1),transparent)}.lang-btn.active{color:var(--primary-soft);background:linear-gradient(90deg,rgba(123,158,189,.14),rgba(168,197,227,.06));box-shadow:var(--shadow-sm)}.lang-btn:focus-visible{outline:2px solid var(--primary-light);outline-offset:2px}.lang-switcher.lang-switcher-compact .lang-btn{padding:.35rem .7rem;font-size:.8rem}.lang-switcher.lang-switcher-compact{padding:.2rem;background:rgba(248,250,252,.95);border-color:var(--border-color)}.lang-switcher.lang-switcher-compact .lang-btn.active{background:linear-gradient(90deg,rgba(123,158,189,.16),rgba(168,197,227,.08))}.lang-switcher.lang-switcher-sidebar{display:flex;justify-content:center;margin-bottom:.25rem;padding:.15rem;background:rgba(248,250,252,.8);border-radius:var(--radius-md)}.lang-switcher.lang-switcher-sidebar .lang-btn{padding:.28rem .55rem;font-size:.8rem}@media (max-width:1024px){.lang-switcher.lang-switcher-header{display:none!important}}@media (min-width:1025px){.btn-logout-header{display:none!important}.user-info-desktop{display:flex!important}}@media (max-width:1024px){.btn-logout-header{display:inline-flex!important;align-items:center;gap:.35rem;padding:.4rem .6rem;font-size:.8rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;transition:all .2s ease}.btn-logout-header:hover{background:rgba(239,68,68,.1);color:#ef4444;border-color:rgba(239,68,68,.3)}.btn-logout-header span{display:none}.user-info-desktop{display:none!important}}.date-format-toggle{display:inline-flex;align-items:center;margin-left:.5rem}.date-format-btn{padding:.35rem .7rem;font-size:.8rem;border:1px solid var(--border-color);border-radius:calc(var(--radius-xl) - 3px);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .25s ease}.date-format-btn:hover{color:var(--primary-soft);background:rgba(123,158,189,.1)}.date-format-btn.active{color:var(--primary-soft);background:rgba(123,158,189,.14)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f5f9}::-webkit-scrollbar-thumb{background:var(--primary-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary-soft)}h1,h2,h3,h4,h5,h6{color:var(--text-primary);font-weight:600}h1{font-size:2rem}h2{font-size:1.5rem}h3{font-size:1.25rem}p{color:var(--text-secondary)}.btn-primary{background:linear-gradient(135deg,var(--primary-soft) 0,var(--primary-light) 100%);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-sm);display:inline-flex;align-items:center;gap:.5rem}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:#fff;color:var(--primary-soft);border:2px solid var(--primary-soft);padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:1rem;font-weight:500;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background:var(--primary-soft);color:#fff}.card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm);transition:all .3s ease}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}input[type=date],input[type=email],input[type=text],select,textarea{width:100%;padding:.75rem 1rem;border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;font-family:inherit;color:var(--text-primary);background:#fff;transition:all .3s ease}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary-soft);box-shadow:0 0 0 3px rgba(123,158,189,.1)}textarea{resize:vertical}.progress-bar-container{width:100%;height:12px;background:var(--border-color);border-radius:10px;overflow:hidden;position:relative}.progress-bar{height:100%;background:linear-gradient(90deg,var(--success-soft) 0,#9dc9a3 100%);border-radius:10px;transition:width .5s ease;position:relative}.progress-bar:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,hsla(0,0%,100%,.3) 50%,transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem;min-height:120px}.loading-spinner i{font-size:2rem;color:var(--primary-soft);animation:spin .8s linear infinite}.loading-spinner span{font-size:.9rem;color:var(--text-secondary)}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.skeleton{background:linear-gradient(90deg,#f4f6f8 25%,#eceff1 37%,#f4f6f8 63%);background-size:400% 100%;animation:shimmer 1.2s ease-in-out infinite;border-radius:6px}.skeleton-text{height:14px;margin:6px 0}.skeleton-title{height:18px;margin:8px 0}.skeleton-avatar{width:40px;height:40px;border-radius:50%}.skeleton-badge{width:70px;height:18px;border-radius:12px}.skeleton-line-sm{height:10px;margin:4px 0}.skeleton-list{display:grid;grid-gap:12px;gap:12px}.scroll-x,.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse}.overview-table td,.overview-table th{min-width:120px}.overview-table .student-col{min-width:180px}.btn-primary,.btn-secondary,button{min-height:44px}@media (max-width:1024px){#sidebar{position:fixed;inset:0 auto 0 0;width:280px;z-index:1001;transform:translateX(-100%);transition:transform .25s ease}#sidebar.active{transform:translateX(0)}}@media (max-width:768px){.mobile-hidden{display:none!important}.mobile-only{display:block!important}.progress-list,.students-grid,.tasks-list,.tasks-list-compact{grid-template-columns:1fr!important}.card,.content-section{padding:.5rem .75rem!important}.section-header{flex-direction:column;align-items:stretch;gap:.35rem;margin-bottom:.75rem!important}.section-header h2,.section-header h3,.section-title{font-size:.95rem!important}.btn-primary,.btn-secondary{padding:.4rem .7rem!important;font-size:.8rem!important;min-height:32px!important}.btn-primary i,.btn-secondary i{font-size:.75rem!important}.form-group{margin-bottom:.5rem!important}.form-group label{font-size:.82rem!important}input,select,textarea{padding:.45rem .65rem!important;font-size:.88rem!important}.modal-content{padding:1rem!important;width:95%!important;max-height:85vh!important;overflow-y:auto!important;-webkit-overflow-scrolling:touch;margin:1rem auto!important}.modal-content h2{font-size:1rem!important}.card,.modal-content h2{margin-bottom:.75rem!important}}.modal{display:none;position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;background-color:rgba(74,85,104,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background-color:#fff;margin:5% auto;padding:2rem;border-radius:var(--radius-lg);width:90%;max-width:500px;box-shadow:var(--shadow-lg);animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.close{color:var(--text-light);float:right;font-size:28px;font-weight:700;cursor:pointer;transition:color .3s ease}.close:hover{color:var(--text-primary)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.checkbox-group{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:.75rem;gap:.75rem;max-height:300px;overflow-y:auto;padding:1rem;background:var(--bg-primary);border-radius:var(--radius-md)}.checkbox-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#fff;border-radius:var(--radius-sm);transition:all .2s ease}.checkbox-item:hover{background:var(--primary-light);color:#fff}.checkbox-item input[type=checkbox]{width:auto;cursor:pointer}.app-container{width:100%}.app-container,.teacher-dashboard{display:flex;min-height:100vh}.sidebar-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:99;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .25s ease,visibility .25s ease}.sidebar-backdrop.active{opacity:1;visibility:visible;pointer-events:auto}.mobile-menu-btn{display:none;background:none;border:none;font-size:1.5rem;color:var(--text-primary);cursor:pointer;padding:.5rem}@media (max-width:1024px){.mobile-menu-btn{display:block}}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--text-secondary)}.loading-state i{font-size:2rem;margin-bottom:1rem;color:var(--primary-soft)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .5s ease}@media (max-width:768px){h1{font-size:1.5rem}h2{font-size:1.25rem}h3{font-size:1.1rem}.checkbox-group{grid-template-columns:1fr}}.landing-container{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:calc(2rem + env(safe-area-inset-top, 0px)) calc(2rem + env(safe-area-inset-right, 0px)) calc(2rem + env(safe-area-inset-bottom, 0px)) calc(2rem + env(safe-area-inset-left, 0px));animation:fadeIn .8s ease;position:relative;box-sizing:border-box;width:100%;max-width:100%;overflow-x:clip}.landing-container .lang-switcher{display:inline-flex;align-items:center;margin-top:.5rem;margin-bottom:1.25rem;padding:.2rem .3rem;background:#fff;box-shadow:var(--shadow-sm);border:1px solid var(--border-color);border-radius:var(--radius-xl)}.landing-container .lang-switcher .lang-btn{padding:.3rem .6rem;font-size:.75rem}.landing-container .lang-btn.active{background:linear-gradient(135deg,rgba(123,158,189,.12),rgba(184,165,214,.08));color:var(--primary-soft)}.welcome-section{text-align:center;margin-bottom:3rem;max-width:760px;width:100%}.landing-container-remembered .welcome-section{margin-bottom:1.25rem}.logo-area{margin-bottom:.5rem}.logo-area i{font-size:5rem;color:var(--primary-soft);background:linear-gradient(135deg,var(--primary-soft),var(--secondary-soft));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.main-title{font-size:2.5rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,var(--primary-soft),var(--secondary-soft));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{font-size:1.1rem;color:var(--text-secondary)}.noticeboard-section{width:100%;max-width:520px;margin-bottom:2rem}.noticeboard-card{background:hsla(0,0%,100%,.95);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.noticeboard-card h3{margin:0;padding:.85rem 1rem;font-size:.95rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:.5rem;border-bottom:1px solid var(--border-color);background:#fff}.noticeboard-card h3 i{color:var(--primary-soft)}.noticeboard-latest{padding:1rem;background:linear-gradient(135deg,#eff6ff,#f8fafc);border-bottom:1px solid var(--border-color)}.noticeboard-latest .notice-title{font-weight:700;font-size:1rem;margin:0 0 .4rem;color:var(--text-primary)}.noticeboard-latest .notice-body{font-size:.9rem;color:var(--text-secondary);line-height:1.5;margin:0 0 .35rem;white-space:pre-wrap}.noticeboard-latest .notice-meta{font-size:.75rem;color:var(--text-light)}.noticeboard-older-trigger{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.6rem 1rem;border:none;border-top:1px solid var(--border-color);background:#fff;font-size:.85rem;font-weight:600;color:var(--primary-soft);cursor:pointer;transition:background .2s}.noticeboard-older-trigger:hover{background:var(--bg-primary)}.noticeboard-older-trigger i{transition:transform .2s}.noticeboard-card.expanded .noticeboard-older-trigger i{transform:rotate(180deg)}.noticeboard-older-wrap{display:none;max-height:160px;overflow-y:auto;padding:.5rem 1rem .75rem;border-top:1px solid var(--border-color);background:rgba(0,0,0,.02)}.noticeboard-card.expanded .noticeboard-older-wrap{display:block}.noticeboard-older .notice-card{padding:.6rem 0;border-bottom:1px solid rgba(0,0,0,.06)}.noticeboard-older .notice-card:last-child{border-bottom:none}.noticeboard-older .notice-title{font-size:.88rem;margin:0 0 .2rem;font-weight:600;color:var(--text-primary)}.noticeboard-older .notice-body{font-size:.8rem;margin:0 0 .15rem;color:var(--text-secondary);line-height:1.45;white-space:pre-wrap}.noticeboard-older .notice-meta{font-size:.7rem;color:var(--text-light)}.remembered-device-banner{margin:1.1rem auto 0;max-width:520px;padding:1rem 1.1rem;border-radius:16px;background:hsla(0,0%,100%,.86);border:1px solid #e2e8f0;box-shadow:var(--shadow-sm)}.remembered-device-banner-head{display:inline-flex;align-items:center;gap:.55rem;color:var(--text-primary);font-weight:700}.remembered-device-banner-head i{color:var(--primary-soft)}.remembered-device-banner p{margin:.55rem 0 0;color:var(--text-secondary);line-height:1.5;font-size:.92rem}.modal-mode-reset,.remembered-device-reset{margin-top:.8rem;background:none;border:none;color:var(--primary-soft);font-size:.88rem;font-weight:700;padding:0;cursor:pointer;text-decoration:underline;text-underline-offset:.15rem}.modal-mode-reset{margin-top:.5rem}.modal-mode-reset-inline{display:inline-flex;margin-top:0;margin-bottom:.75rem}.selection-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:2rem;width:100%;box-sizing:border-box}.selection-cards,.selection-cards-remembered{gap:2rem;max-width:800px}.role-card-remembered{max-width:100%;margin:0}.role-card{background:#fff;border-radius:var(--radius-xl);padding:2.5rem 2rem;text-align:center;cursor:pointer;transition:all .4s cubic-bezier(.175,.885,.32,1.275);box-shadow:var(--shadow-sm);position:relative;overflow:hidden;box-sizing:border-box;width:100%}.role-card-badge{position:absolute;top:1rem;right:1rem;min-width:2rem;height:2rem;padding:0 .55rem;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;justify-content:center;font-size:.85rem;font-weight:700;box-shadow:0 10px 24px rgba(220,38,38,.28)}.role-card-badge,.role-card-meta{border-radius:999px;display:inline-flex;align-items:center}.role-card-meta{gap:.45rem;margin-bottom:1rem;padding:.45rem .8rem;background:#fef2f2;color:#b91c1c;font-size:.82rem;font-weight:600;max-width:100%;text-align:center}.role-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--primary-soft),var(--primary-light));transform:scaleX(0);transition:transform .4s ease}.role-card:hover:before{transform:scaleX(1)}.role-card:hover{transform:translateY(-10px);box-shadow:var(--shadow-lg)}.teacher-card:hover{border:2px solid var(--primary-soft)}.student-card:hover{border:2px solid var(--secondary-soft)}.spreadsheet-card:hover{border:2px solid var(--success-soft)}.spreadsheet-card .card-icon{background:linear-gradient(135deg,#dcfce7,#bbf7d0)}.spreadsheet-card .card-icon i{color:var(--success-soft)}.landing-quick-quiz-card .card-icon,.quiz-card .card-icon{background:linear-gradient(135deg,#fff7ed,#ffedd5)}.landing-quick-quiz-card .card-icon i,.quiz-card .card-icon i{color:#ea580c}.landing-quick-quiz-card{text-align:left}.landing-quiz-questions-scroll{max-height:120px;overflow-y:auto;margin:.5rem 0 .75rem;padding-right:.25rem;-webkit-overflow-scrolling:touch}.landing-quiz-questions-scroll::-webkit-scrollbar{width:5px}.landing-quiz-questions-scroll::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.landing-quiz-questions-list{list-style:none;margin:0;padding:0;font-size:.85rem;color:var(--text-primary);line-height:1.35}.landing-quiz-questions-list li{padding:.25rem 0;border-bottom:1px solid var(--border-color);display:flex;align-items:flex-start;gap:.35rem}.landing-quiz-questions-list li:last-child{border-bottom:none}.landing-quiz-questions-list .q-num{flex-shrink:0;font-size:.75rem;color:var(--primary-soft);font-weight:600}.landing-quick-quiz-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;font-size:.9rem;font-weight:600;border:none;border-radius:10px;background:linear-gradient(135deg,#ea580c,#f97316);color:#fff;cursor:pointer;box-shadow:0 2px 6px rgba(234,88,12,.25)}.landing-quick-quiz-btn:hover{opacity:.95;transform:translateY(-1px)}.card-icon{width:80px;height:80px;margin:0 auto 1.5rem;background:linear-gradient(135deg,var(--bg-primary),#fff);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .4s ease}.teacher-card .card-icon{background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.student-card .card-icon{background:linear-gradient(135deg,#f3e5f5,#e1bee7)}.card-icon i{font-size:2.5rem;transition:all .4s ease}.teacher-card .card-icon i{color:var(--primary-soft)}.student-card .card-icon i{color:var(--secondary-soft)}.role-card:hover .card-icon{transform:scale(1.1) rotate(5deg)}.role-card h2{font-size:1.75rem;margin-bottom:.75rem;color:var(--text-primary)}.role-card p{color:var(--text-secondary);font-size:1rem;margin-bottom:1.5rem}.card-arrow{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:var(--bg-primary);transition:all .3s ease}.card-arrow i{color:var(--primary-soft);font-size:1.2rem;transition:transform .3s ease}.role-card:hover .card-arrow{background:var(--primary-soft)}.role-card:hover .card-arrow i{color:#fff;transform:translateX(5px)}.footer-note{margin-top:3rem;text-align:center}.footer-note p{color:var(--text-light);font-size:.95rem}@media (max-width:768px){.landing-container{padding:calc(.5rem + env(safe-area-inset-top, 0px)) calc(.75rem + env(safe-area-inset-right, 0px)) calc(.75rem + env(safe-area-inset-bottom, 0px)) calc(.75rem + env(safe-area-inset-left, 0px));justify-content:flex-start;min-height:100vh;min-height:100dvh;overflow-x:hidden}.landing-container .lang-switcher{margin-top:.35rem;margin-bottom:.6rem;padding:.15rem .25rem}.landing-container .lang-switcher .lang-btn{padding:.25rem .5rem;font-size:.7rem}.welcome-section{margin-bottom:.75rem}.logo-area{margin-bottom:.35rem}.logo-area i{font-size:2.25rem}.main-title{font-size:1.25rem;margin-bottom:.25rem}.subtitle{font-size:.8rem}.remembered-device-banner{margin-top:.75rem;padding:.8rem .9rem}.remembered-device-banner p{font-size:.8rem}.selection-cards{grid-template-columns:1fr;gap:.6rem;max-width:100%;width:100%}.role-card-remembered,.selection-cards-remembered{max-width:100%}.role-card{padding:.75rem 1rem;min-height:44px;text-align:center}.role-card .card-icon{width:44px;height:44px;margin:0 auto .5rem}.role-card .card-icon i{font-size:1.35rem}.role-card h2{font-size:.95rem;margin-bottom:.25rem}.role-card p{font-size:.72rem;margin-bottom:.5rem;line-height:1.3}.role-card-badge{top:.75rem;right:.75rem;min-width:1.75rem;height:1.75rem;font-size:.78rem}.role-card-meta{display:flex;justify-content:center;flex-wrap:wrap;padding:.35rem .65rem;font-size:.72rem;margin-bottom:.6rem}.role-card .card-arrow{width:28px;height:28px;margin:0 auto}.role-card .card-arrow i{font-size:.85rem}.footer-note{margin-top:.5rem}.footer-note p{font-size:.75rem}}.login-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem;overflow-y:auto;overflow-x:hidden;box-sizing:border-box}.login-modal{background:#fff;border-radius:16px;padding:2rem;max-width:400px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.2);position:relative;box-sizing:border-box;max-height:calc(100dvh - 2rem);overflow:auto}.login-modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:1.25rem;color:var(--text-secondary);cursor:pointer;padding:.25rem}.login-modal-close:hover,.login-modal-title{color:var(--text-primary)}.login-modal-title{margin:0 0 1.5rem;font-size:1.5rem}.login-modal-subtitle{margin:-.5rem 0 1.25rem;color:var(--text-secondary);font-size:.95rem}.teacher-login-summary{display:flex;gap:.85rem;align-items:flex-start;padding:.95rem 1rem;margin-bottom:1rem;border-radius:14px;background:linear-gradient(135deg,#eff6ff,#f8fafc);border:1px solid #dbeafe}.teacher-login-summary-icon{width:2.4rem;height:2.4rem;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#dbeafe;color:#2563eb;flex-shrink:0}.teacher-login-summary-content{display:flex;flex-direction:column;gap:.2rem;min-width:0}.teacher-login-summary-content strong{color:#1e3a8a;font-size:.95rem}.teacher-login-summary-content span{color:#2563eb;font-weight:700;line-height:1.4}.teacher-login-summary-content small{color:#64748b;line-height:1.45}.login-modal.login-modal-student{max-width:960px;padding:1.5rem}.student-login-layout{display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.9fr);grid-gap:1.25rem;gap:1.25rem;align-items:stretch;width:100%;max-width:100%;box-sizing:border-box}.student-login-form-panel,.student-login-list-panel{background:#fafbfc;border:1px solid #e5e7eb;border-radius:14px;padding:1rem;box-sizing:border-box;min-width:0}.student-login-list-header{margin-bottom:.9rem}.student-login-list-header h3{margin:0 0 .35rem;font-size:1.05rem}.student-login-form-hint,.student-login-list-header p{margin:0;color:var(--text-secondary);font-size:.9rem}.student-login-list{display:flex;flex-direction:column;gap:.75rem;max-height:420px;overflow:auto;padding-right:.25rem}.student-login-row{width:100%;border:1px solid #e5e7eb;background:#fff;border-radius:12px;padding:.9rem;text-align:left;cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,transform .2s ease;box-sizing:border-box;overflow:hidden}.student-login-row.active,.student-login-row:hover{border-color:var(--primary-soft);box-shadow:0 10px 22px rgba(59,130,246,.12);transform:translateY(-1px)}.student-login-row.active{background:linear-gradient(135deg,#f8fbff,#fff)}.student-login-row-main{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.student-login-row-primary{min-width:0;display:flex;align-items:center;gap:.5rem;flex:1 1 auto;flex-wrap:wrap}.student-login-row-name{font-weight:700;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.student-login-row-id{color:#475569;font-size:.76rem;font-weight:700;letter-spacing:.02em;display:inline-flex;align-items:center;padding:.14rem .46rem;border-radius:999px;background:#f1f5f9;border:1px solid #e2e8f0;white-space:nowrap;flex-shrink:0}.student-login-row-status-badges{display:flex;justify-content:flex-end;flex-shrink:0}.student-login-row-status{display:inline-flex;align-items:center;justify-content:center;min-height:1.9rem;padding:.2rem .65rem;border-radius:999px;font-size:.76rem;font-weight:700;white-space:nowrap}.student-login-row-status.unread{background:linear-gradient(135deg,#dbeafe,#bfdbfe);color:#1d4ed8}.student-login-row-side{display:flex;justify-content:space-between;align-items:center;margin-top:.35rem;gap:.5rem}.student-login-row-status-text{font-size:.8rem;color:#64748b;font-weight:600;line-height:1.35}.student-login-row-preview{margin-top:.55rem;display:flex;gap:.3rem;color:var(--text-secondary);font-size:.84rem}.student-login-row-preview-label{font-weight:600;white-space:nowrap}.student-login-row-preview-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.student-login-empty{min-height:180px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.65rem;color:var(--text-secondary);text-align:center}.student-login-empty i{font-size:1.8rem;color:var(--primary-soft)}.login-selected-student{margin-bottom:1rem;padding:.8rem .9rem;border-radius:12px;background:#eff6ff;color:#1d4ed8;display:flex;flex-direction:column;gap:.2rem}.login-selected-student-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}.login-selected-student-id{color:#2563eb;font-size:.88rem;font-weight:600}.login-form-group{margin-bottom:1.25rem}.login-form-group label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.95rem;color:var(--text-primary)}.login-form-group input{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:10px;font-size:1rem;box-sizing:border-box}.login-form-group input:focus{outline:none;border-color:var(--primary-soft)}.login-error{color:#dc2626;font-size:.9rem;margin-bottom:1rem}.login-submit-btn{width:100%;padding:.85rem 1.5rem;background:linear-gradient(135deg,var(--primary-soft),var(--primary-light));color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem}.login-submit-btn:hover:not(:disabled){opacity:.95}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed}@media (max-width:900px){.student-login-layout{grid-template-columns:1fr}.login-modal.login-modal-student{max-width:640px}.student-login-list{max-height:260px}}@media (max-width:640px){.login-modal-overlay{align-items:flex-start;padding:.75rem}.login-modal,.login-modal.login-modal-student{width:100%;max-width:100%;padding:1rem;border-radius:14px;max-height:calc(100dvh - 1.5rem)}.login-modal-title{font-size:1.25rem;margin-bottom:1rem;padding-right:1.5rem}.login-modal-subtitle{margin:-.35rem 0 1rem;font-size:.88rem;line-height:1.4}.modal-mode-reset,.remembered-device-reset{font-size:.82rem}.teacher-login-summary{padding:.8rem .85rem;gap:.7rem}.teacher-login-summary-icon{width:2rem;height:2rem}.student-login-form-panel,.student-login-list-panel{padding:.85rem}.student-login-list{max-height:min(38dvh,320px)}.student-login-row{padding:.8rem}.student-login-row-main{align-items:flex-start;flex-direction:column;gap:.45rem}.student-login-row-primary{align-items:center}.student-login-row-primary,.student-login-row-status-badges{width:100%;justify-content:flex-start}.student-login-row-side{margin-top:.45rem}.student-login-row-status-text{font-size:.76rem}.student-login-row-preview{font-size:.78rem}.student-login-row-preview-text{white-space:normal;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}}@media (max-width:420px){.landing-container{padding-left:.65rem;padding-right:.65rem}.main-title{font-size:1.15rem}.subtitle{font-size:.76rem}.role-card{padding:.75rem .85rem}.student-login-list-header h3{font-size:.98rem}}