@import"https://fonts.googleapis.com/css2?family=Inter+Tight:ital,wght@0,100..900;1,100..900&display=swap";:root{--color-primary: #0A2E5D;--color-accent: #e0591e;--color-primary-rgb: 10, 46, 93;--color-primary-hover: 204, 225, 252;--color-bg: #F8FAFC;--color-card: #FFFFFF;--color-card-hover: #F1F5F9;--color-border: #E2E8F0;--color-text-primary: #1E293B;--color-text-secondary: #475569;--color-text-inverse: #FFFFFF;--color-success: #16A34A;--color-warning: #F59E0B;--color-error: #DC2626;--color-success-bg: #DCFCE7;--color-warning-bg: #FEF3C7;--color-error-bg: #FEE2E2;--font-family: "Inter Tight", system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-size-h1: clamp(1.75rem, 1.5vw + 1rem, 1.5rem);--font-size-h2: clamp(1.25rem, 1.5vw + .6rem, 1.75rem);--font-size-h3: clamp(1.125rem, 1.2vw + .4rem, 1.5rem);--font-size-body: clamp(.95rem, .8vw + .4rem, 1rem);--font-size-primary-text: clamp(1rem, 1vw + .4rem, 1.125rem);--font-size-secondary-text: clamp(.875rem, .6vw + .3rem, .95rem);--font-size-label: clamp(.75rem, .5vw + .3rem, .875rem);--font-size-table: clamp(.85rem, .6vw + .35rem, .95rem);--font-size-button: clamp(.875rem, .6vw + .35rem, 1rem);--font-size-caption: clamp(.75rem, .5vw + .3rem, .85rem);--font-size-tiny: clamp(.65rem, .4vw + .25rem, .75rem);--line-height-tight: 1.2;--line-height-normal: 1.5;--line-height-loose: 1.8;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--shadow-card: 0 2px 6px rgba(0, 0, 0, .05)}*{box-sizing:border-box}body{margin:0;padding:0;font-family:var(--font-family);font-size:var(--font-size-body);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg)}h1{font-size:var(--font-size-h1);line-height:var(--line-height-tight);color:var(--color-text-primary);font-weight:600}h2{font-size:var(--font-size-h2);line-height:var(--line-height-tight);color:var(--color-text-primary);font-weight:600}h3{font-size:var(--font-size-h3);line-height:var(--line-height-tight);color:var(--color-text-primary);font-weight:600}p{font-size:var(--font-size-body);line-height:var(--line-height-normal);color:var(--color-text-secondary)}button{font-family:var(--font-family);font-size:var(--font-size-button)}.card{background-color:var(--color-card);border:1px solid var(--color-border);box-shadow:var(--shadow-card)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;height:100%}.loading-spinner{width:40px;height:40px;border:4px solid var(--color-border);border-top:4px solid var(--color-primary);border-radius:50%;animation:app-detail-spin 1s linear infinite}@keyframes app-detail-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.breadCrums{display:flex;gap:5px}.breadCrums .breadCrum-text{text-decoration:none;color:var(--color-text-primary);font-size:15px;font-weight:600}.breadCrums .last-link{color:var(--color-accent)}.progress-container{width:300px;height:8px;background:#e0e0e0;border-radius:4px;position:relative}.progress-bar{height:100%;background:#4caf50;border-radius:4px;transition:width .2s ease}.progress-text{margin-left:8px;font-size:14px}.sb-main{position:fixed;top:0;left:0;height:100vh;width:280px;z-index:1000;display:flex;flex-direction:column;transition:width .4s cubic-bezier(.4,0,.2,1),transform .4s cubic-bezier(.4,0,.2,1);padding:1.5rem 0}.sb-main--mobile{transform:translate(-100%);background:#fff;box-shadow:10px 0 40px #0000001a}.sb-main--mobile.sb-main--open{transform:translate(0)}.sb-main--desktop{position:fixed;transform:translate(0)}.sb-main--desktop.sb-main--collapsed{width:88px}.sb-overlay{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:999}.sb-header{display:flex;align-items:center;justify-content:center;padding:0 1.5rem 1.5rem;position:relative;border:none;margin-bottom:0}.sb-logo{display:flex;align-items:center;gap:.75rem;min-width:0}.sb-logo-icon{font-size:1.75rem;min-width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary),#1a4d8c);border-radius:12px;box-shadow:0 4px 12px #0a2e5d26;color:#fff}.sb-logo-text{font-size:1.2rem;font-weight:800;color:var(--color-primary);white-space:nowrap;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1);letter-spacing:-.02em;opacity:1;visibility:visible;width:auto}.sb-toggle{position:absolute;right:-17px;top:50%;transform:translateY(-50%);background:var(--color-primary);border:3px solid #F8FAFC;color:#fff;cursor:pointer;padding:.5rem;border-radius:50%;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;width:34px;height:34px;box-shadow:0 4px 12px #0a2e5d33;z-index:1001}.sb-toggle:hover{transform:translateY(-50%) scale(1.15);background:var(--color-accent)}.sb-toggle-icon{transition:transform .4s cubic-bezier(.4,0,.2,1);width:16px;height:16px}.sb-toggle-icon.rotated{transform:rotate(180deg)}.sb-nav{flex:1;padding:0 1rem;margin-top:1.8rem;overflow-y:auto;overflow-x:hidden}.sb-main--desktop.sb-main--collapsed .sb-nav{padding:0 .5rem}.sb-group{margin-bottom:1.5rem}.sb-group:first-child{border-top:none;margin-top:0;padding-top:0}.sb-group-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem .75rem;cursor:pointer;border-radius:8px;transition:all .4s cubic-bezier(.4,0,.2,1);margin-bottom:.5rem;background:#1e40af1f;opacity:1;visibility:visible;height:auto;overflow:hidden}.sb-group-header:hover{background:#0a2e5d0a}.sb-group-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-secondary);opacity:.7;white-space:nowrap}.sb-menu{list-style:none;margin:0;padding:0;overflow:hidden;transition:all .4s cubic-bezier(.4,0,.2,1)}.sb-menu.hide{max-height:0;opacity:0}.sb-menu.show{max-height:1000px;opacity:1}.sb-menu-item{margin-bottom:4px;transition:transform .4s cubic-bezier(.4,0,.2,1)}.sb-menu-link{display:flex;align-items:center;padding:.75rem 1rem;color:var(--color-text-secondary);text-decoration:none;border-radius:12px;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;font-weight:500;font-size:.9rem}.sb-menu-link:hover{background:#0a2e5d0f;color:var(--color-primary);transform:translate(4px)}.sb-menu-link.active{background:linear-gradient(135deg,#0a2e5d14,#0a2e5d0a);color:var(--color-primary);font-weight:600;box-shadow:inset 3px 0 0 var(--color-primary)}.sb-menu-icon{margin-right:.85rem;width:20px;display:flex;align-items:center;justify-content:center;color:inherit;flex-shrink:0;transition:all .3s ease}.sb-menu-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:all .4s cubic-bezier(.4,0,.2,1);flex:1;opacity:1;visibility:visible}.sb-menu-badge{background:var(--color-accent);color:#fff;font-size:.7rem;padding:.15rem .5rem;border-radius:10px;font-weight:700;box-shadow:0 2px 5px #e0591e4d;transition:all .4s cubic-bezier(.4,0,.2,1);opacity:1;visibility:visible}.sb-footer{padding:1.5rem 1.25rem;border-top:1px solid rgba(10,46,93,.08)}.sb-user-profile{display:flex;align-items:center;gap:.85rem;cursor:pointer;padding:.5rem;border-radius:12px;transition:all .2s ease}.sb-user-profile:hover{background:#0a2e5d0a}.sb-user-avatar{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--color-primary),#1a4d8c);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;box-shadow:0 4px 10px #0a2e5d26}.sb-user-info{flex:1;min-width:0;transition:all .4s cubic-bezier(.4,0,.2,1);opacity:1;visibility:visible}.sb-user-name{font-size:.9rem;font-weight:700;color:var(--color-primary);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-user-role{font-size:.75rem;color:var(--color-text-secondary)}.sb-main--desktop.sb-main--collapsed .sb-logo-text,.sb-main--desktop.sb-main--collapsed .sb-menu-label,.sb-main--desktop.sb-main--collapsed .sb-menu-badge,.sb-main--desktop.sb-main--collapsed .sb-user-info,.sb-main--desktop.sb-main--collapsed .sb-group-header{opacity:0!important;visibility:hidden!important;max-width:0!important;margin:0!important;padding:0!important;pointer-events:none!important}.sb-main--desktop.sb-main--collapsed .sb-group-header{height:0!important;margin-bottom:0!important}.sb-main--desktop.sb-main--collapsed .sb-menu-item{transform:translate(-5px)}.sb-main--desktop.sb-main--collapsed .sb-group{margin-bottom:0}.sb-main--desktop.sb-main--collapsed .sb-header{justify-content:center;padding:0 0 1.5rem}.sb-main--desktop.sb-main--collapsed .sb-menu-link{justify-content:center;padding:.75rem}.sb-main--desktop.sb-main--collapsed .sb-menu-icon{margin-right:0}.sb-main--desktop.sb-main--collapsed .sb-footer{display:flex;justify-content:center;padding:1.5rem .5rem}.sb-main--desktop.sb-main--collapsed .sb-user-profile{justify-content:center}.sb-tooltip-global{position:fixed;background:var(--color-primary);color:#fff;padding:.6rem 1rem;border-radius:8px;font-size:.8rem;font-weight:600;z-index:2000;box-shadow:0 4px 20px #00000026;pointer-events:none;animation:tooltipIn .2s ease-out}.sb-tooltip-global:after{content:"";position:absolute;left:-6px;top:50%;transform:translateY(-50%);border:6px solid transparent;border-right-color:var(--color-primary)}@keyframes tooltipIn{0%{opacity:0;transform:translateY(-50%) translate(-10px)}to{opacity:1;transform:translateY(-50%) translate(0)}}.sb-nav::-webkit-scrollbar{width:3px}.sb-nav::-webkit-scrollbar-track{background:transparent}.sb-nav::-webkit-scrollbar-thumb{background:#0a2e5d1a;border-radius:10px}.sb-nav::-webkit-scrollbar-thumb:hover{background:#0a2e5d33}@media(max-width:767px){.sb-main--mobile{width:300px;height:100vh;border-radius:0}.sb-main--mobile .sb-header{padding-top:2rem}.sb-toggle{display:none}}.notif-modal-overlay{position:fixed;inset:0;background:transparent;display:flex;justify-content:flex-end;align-items:flex-start;z-index:9999;animation:fadeIn .2s ease-out;padding:20px;pointer-events:none}.notif-modal-overlay>*{pointer-events:auto}@keyframes slideIn{0%{transform:translateY(-20px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.notif-modal-modern{width:100%;max-width:420px;max-height:75vh;background:#fff;border-radius:16px;overflow:hidden;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;box-shadow:0 4px 24px #00000026,0 0 0 1px #0000000d;animation:slideIn .3s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;margin-top:70px;margin-right:16px}.notif-header-glass{padding:16px 20px;background:linear-gradient(135deg,var(--color-primary),#1a4d8c);color:#fff;position:relative}.notif-header-content{display:flex;justify-content:space-between;align-items:center;gap:16px}.notif-header-left,.notif-header-right{display:flex;align-items:center;gap:12px}.notif-header-icon{color:#fff;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.notif-header-title{margin:0;color:#fff;font-size:18px;font-weight:600;letter-spacing:-.01em}.notif-unread-pill{display:flex;align-items:center;gap:4px;background:#fff3;padding:4px 10px;border-radius:12px;font-size:.75rem;font-weight:600;border:1px solid rgba(255,255,255,.3)}.notif-unread-dot{width:6px;height:6px;background:#fff;border-radius:50%;box-shadow:0 0 8px #fff9;animation:notifDotPulse 2s ease-in-out infinite}@keyframes notifDotPulse{0%,to{opacity:1}50%{opacity:.5}}.notif-close-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;padding:8px;cursor:pointer;color:#fff;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.notif-close-btn:hover{background:#fff3;transform:scale(1.05)}.notif-tabs{display:flex;gap:0;background:#f8fafc;border-bottom:1px solid #e2e8f0}.notif-tab{flex:1;padding:12px 16px;border:none;cursor:pointer;background:transparent;color:#64748b;font-weight:500;font-size:14px;transition:all .2s ease;position:relative;border-bottom:2px solid transparent;display:flex;align-items:center;justify-content:center;gap:6px}.notif-tab:hover{background:#f1f5f9;color:#475569}.notif-tab.active{background:#fff;color:#1e293b;border-bottom-color:#1e293b}.notif-tab-badge{background:#ef4444;color:#fff;font-size:.625rem;font-weight:700;padding:2px 6px;border-radius:6px;min-width:16px;text-align:center;line-height:1.2}.notif-mark-all-container{padding:8px 12px;background:#f8fafccc;border-bottom:1px solid rgba(10,46,93,.06)}.notif-mark-all-btn{width:100%;padding:8px 12px;border:1px solid #e2e8f0;background:#fff;color:#1e293b;font-size:.813rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px}.notif-mark-all-btn:hover{background:#1e293b;color:#fff;border-color:#1e293b;transform:translateY(-1px);box-shadow:0 2px 8px #1e293b26}.notif-mark-all-btn:active{transform:translateY(0)}.notif-list-container{flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:rgba(10,46,93,.15) transparent}.notif-list-container::-webkit-scrollbar{width:6px}.notif-list-container::-webkit-scrollbar-track{background:transparent}.notif-list-container::-webkit-scrollbar-thumb{background:#0a2e5d1f;border-radius:10px;transition:background .3s ease}.notif-list-container::-webkit-scrollbar-thumb:hover{background:#0a2e5d33}.notif-items-list{padding:8px 0}.notif-card{margin:0 6px 4px;border-radius:8px;background:#fff;border:1px solid #f1f5f9;transition:all .2s ease;cursor:pointer;animation:notifCardFadeIn .3s ease backwards;position:relative;overflow:hidden}@keyframes notifCardFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.notif-card:before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:transparent;transition:all .2s ease}.notif-card-unread{background:#f8fafc;border-color:#e2e8f0}.notif-card-unread:before{background:#1e293b}.notif-card:not(.notif-card-unread){background:#fafafa;border-color:#f0f0f0;opacity:.8}.notif-card:hover{transform:translate(2px);box-shadow:0 4px 12px #00000014;border-color:#d1d5db}.notif-card-inner{padding:8px;display:flex;gap:8px}.notif-icon-container{flex-shrink:0}.notif-icon-circle{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;position:relative;transition:all .2s ease}.notif-card:hover .notif-icon-circle{transform:scale(1.02)}.notif-card-unread .notif-icon-circle.homework{background:linear-gradient(135deg,#fef3c7,#fde68a);box-shadow:0 4px 12px #fbbf244d}.notif-card-unread .notif-icon-circle.grade-update{background:linear-gradient(135deg,#d1fae5,#a7f3d0);box-shadow:0 4px 12px #10b9814d}.notif-card-unread .notif-icon-circle.reminder{background:linear-gradient(135deg,#fee2e2,#fecaca);box-shadow:0 4px 12px #ef44444d}.notif-card-unread .notif-icon-circle.announcement{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);box-shadow:0 4px 12px #6366f14d}.notif-card-unread .notif-icon-circle.default{background:linear-gradient(135deg,#dbeafe,#bfdbfe);box-shadow:0 4px 12px #3b82f64d}.notif-card:not(.notif-card-unread) .notif-icon-circle.homework{background:linear-gradient(135deg,#fefce8,#fef9e7);box-shadow:0 2px 8px #fbbf241f}.notif-card:not(.notif-card-unread) .notif-icon-circle.grade-update{background:linear-gradient(135deg,#f0fdf4,#ecfdf5);box-shadow:0 2px 8px #10b9811f}.notif-card:not(.notif-card-unread) .notif-icon-circle.reminder{background:linear-gradient(135deg,#fef2f2,#fee2e2);box-shadow:0 2px 8px #ef44441f}.notif-card:not(.notif-card-unread) .notif-icon-circle.announcement{background:linear-gradient(135deg,#eef2ff,#e0e7ff);box-shadow:0 2px 8px #6366f11f}.notif-card:not(.notif-card-unread) .notif-icon-circle.default{background:linear-gradient(135deg,#eff6ff,#dbeafe);box-shadow:0 2px 8px #3b82f61f}.notif-icon{filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.notif-card-unread .notif-icon.homework{color:#d97706}.notif-card-unread .notif-icon.grade{color:#059669}.notif-card-unread .notif-icon.reminder{color:#dc2626}.notif-card-unread .notif-icon.announcement{color:#6366f1}.notif-card-unread .notif-icon.default{color:#2563eb}.notif-card:not(.notif-card-unread) .notif-icon.homework{color:#ca8a04;opacity:.65}.notif-card:not(.notif-card-unread) .notif-icon.grade{color:#10b981;opacity:.65}.notif-card:not(.notif-card-unread) .notif-icon.reminder{color:#f87171;opacity:.65}.notif-card:not(.notif-card-unread) .notif-icon.announcement{color:#818cf8;opacity:.65}.notif-card:not(.notif-card-unread) .notif-icon.default{color:#60a5fa;opacity:.65}.notif-content-area{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.notif-content-header{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.notif-card-unread .notif-title-text{margin:0;font-size:.9375rem;font-weight:800;color:#0f172a;line-height:1.4;letter-spacing:-.01em}.notif-card:not(.notif-card-unread) .notif-title-text{margin:0;font-size:.9375rem;font-weight:700;color:#64748b;line-height:1.4;letter-spacing:-.01em}.notif-mark-read{flex-shrink:0;background:#0a2e5d0f;border:1px solid rgba(10,46,93,.1);border-radius:8px;padding:6px;cursor:pointer;transition:all .2s ease;color:#0a2e5d;display:flex;align-items:center;justify-content:center}.notif-mark-read:hover{background:#0a2e5d;color:#fff;transform:scale(1.1);box-shadow:0 4px 12px #0a2e5d33}.notif-message-content{margin:0}.msg-box{padding:8px 10px;border-radius:8px;font-size:13px;line-height:1.4;margin:4px 0;border:1px solid transparent;position:relative;overflow:hidden}.msg-box:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:currentColor;opacity:.6}.green{background:linear-gradient(135deg,#ecfdf5,#f0fdf4);color:#065f46;border-color:#a7f3d0}.blue{background:linear-gradient(135deg,#eff6ff,#f0f9ff);color:#1e40af;border-color:#93c5fd}.yellow{background:linear-gradient(135deg,#fffbeb,#fef3c7);color:#92400e;border-color:#fcd34d}.red{background:linear-gradient(135deg,#fef2f2,#fee2e2);color:#b91c1c;border-color:#fca5a5}.purple{background:linear-gradient(135deg,#faf5ff,#f3e8ff);color:#6b21a8;border-color:#c4b5fd}.reply-btn{margin-top:12px;font-size:13px;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:8px 16px;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #667eea33}.reply-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.reply-btn:active{transform:translateY(0)}.plain-text{font-size:14px;color:#475569;line-height:1.6;margin:0}.file{margin-top:10px;font-size:13px;color:#667eea;font-weight:500;padding:8px 12px;background:#f8fafc;border-radius:8px;border:1px dashed #cbd5e1;display:inline-block}.notif-footer-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-top:4px}.notif-time-badge{display:flex;align-items:center;gap:5px;font-size:.75rem;color:#94a3b8;font-weight:600}.notif-new-badge{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:.625rem;font-weight:800;padding:3px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 2px 8px #ef44444d}.notif-empty-state{padding:60px 32px;text-align:center;display:flex;flex-direction:column;align-items:center}.notif-empty-icon-wrapper{margin-bottom:24px}.notif-empty-icon-bg{width:88px;height:88px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#0ea5e9;box-shadow:0 0 0 12px #0ea5e90d,0 0 0 24px #0ea5e908;animation:notifEmptyFloat 3s ease-in-out infinite}@keyframes notifEmptyFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.notif-empty-title{margin:0 0 8px;font-size:1.125rem;font-weight:800;color:#0f172a;letter-spacing:-.02em}.notif-empty-desc{margin:0;font-size:.875rem;color:#64748b;line-height:1.6;max-width:280px}.notif-loading-state{padding:60px 32px;display:flex;flex-direction:column;align-items:center;gap:20px}.notif-spinner-ring{display:inline-block;position:relative;width:48px;height:48px}.notif-spinner-ring div{box-sizing:border-box;display:block;position:absolute;width:40px;height:40px;margin:4px;border:4px solid #667eea;border-radius:50%;animation:notifSpinnerRing 1.2s cubic-bezier(.5,0,.5,1) infinite;border-color:#667eea transparent transparent transparent}.notif-spinner-ring div:nth-child(1){animation-delay:-.45s}.notif-spinner-ring div:nth-child(2){animation-delay:-.3s}.notif-spinner-ring div:nth-child(3){animation-delay:-.15s}@keyframes notifSpinnerRing{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.notif-loading-text{margin:0;font-size:.875rem;color:#64748b;font-weight:600}.notif-footer-glass{display:none}.notif-view-all-btn{width:100%;background:#1e293b;color:#fff;border:none;padding:10px 16px;border-radius:8px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:6px}.notif-view-all-btn:hover{background:#0f172a;transform:translateY(-1px);box-shadow:0 4px 12px #1e293b33}.notif-view-all-btn:active{transform:translateY(0)}@media(max-width:640px){.notif-modal-modern{width:calc(100vw - 24px);max-width:none;margin:12px;max-height:calc(100vh - 24px)}.notif-header-glass{padding:20px 24px 16px}.notif-card{margin:0 8px 8px}.notif-card-inner{padding:14px}.notif-icon-circle{width:40px;height:40px}.notif-header-title{font-size:18px}}@media(prefers-color-scheme:dark){.notif-modal-modern{background:#0f172af2;box-shadow:0 0 0 1px #ffffff1a,0 20px 60px #0006}.notif-header-glass{background:linear-gradient(135deg,#1e293b,#334155)}.notif-footer-glass{background:linear-gradient(to top,#1e293bcc,#0f172a99);border-color:#ffffff14}.notif-card{background:#1e293b99;border-color:#ffffff14}.notif-card-unread{background:linear-gradient(to right,#3b82f61a,#1e293b99)}.notif-title-text{color:#f1f5f9}.plain-text{color:#cbd5e1}.notif-empty-title{color:#f1f5f9}}.header{position:relative;z-index:900;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);min-height:80px;width:100%}.ph-container{display:flex;align-items:center;justify-content:space-between;padding:1rem 2.5rem;height:100%}.ph-left{display:flex;align-items:center;gap:1.5rem}.ph-menu-toggle{background:none;border:none;padding:.75rem;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.ph-menu-toggle:hover{background:var(--color-card-hover);color:var(--color-text-primary)}.ph-welcome-title{font-size:var(--font-body);font-weight:600;color:var(--color-text-primary);margin:0;line-height:1.2}.ph-user-highlight{color:var(--color-primary);font-weight:700}.ph-datetime{display:flex;align-items:center;gap:.5rem;font-size:var(--font-size-secondary-text);color:var(--color-text-secondary);margin-top:.25rem}.ph-time-separator{opacity:.5}.ph-right{display:flex!important;flex-direction:row!important;align-items:center!important;gap:1.25rem!important;flex-wrap:nowrap!important}.ph-action{position:relative;display:flex;align-items:center}.ph-btn{background:none;border:none;padding:.75rem;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;position:relative}.ph-btn:hover{background:var(--color-card-hover);color:var(--color-text-primary)}.ph-icon{width:20px;height:20px}.ph-lang-btn{display:flex;align-items:center;gap:.25rem}.ph-current-flag{width:22px;height:16px;border-radius:2px;object-fit:cover;box-shadow:0 1px 3px #0000001a}.ph-chevron{transition:transform .2s ease;color:var(--color-text-secondary);width:16px;height:16px;margin-left:4px}.ph-rotate{transform:rotate(180deg)}.ph-lang-dropdown{position:absolute;top:100%;right:0;width:180px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 10px 25px #0000001a;margin-top:.75rem;z-index:1000;overflow:hidden;animation:phSlideDown .2s ease}.ph-lang-options{padding:.5rem}.ph-lang-option{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;cursor:pointer;transition:background-color .2s ease;font-size:.9rem;border-radius:var(--radius-md);color:var(--color-text-primary)}.ph-lang-option:hover{background-color:var(--color-card-hover)}.ph-lang-option.ph-active{background-color:rgba(var(--color-primary-rgb),.05);color:var(--color-primary);font-weight:600}.ph-lang-flag{width:20px;height:15px;border-radius:1px;object-fit:cover}.ph-lang-label{flex:1;text-align:left}.ph-checkmark{width:14px;height:14px;color:var(--color-primary)}.ph-profile-trigger{display:flex;align-items:center;gap:.5rem;background:none;border:none;padding:.5rem;border-radius:var(--radius-lg);cursor:pointer;transition:all .2s ease}.ph-profile-trigger:hover{background-color:var(--color-card-hover)}.ph-avatar{width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,var(--color-primary),#1a4d8c);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.9rem;box-shadow:0 4px 10px #0a2e5d26}.ph-profile-dropdown{position:absolute;top:100%;right:0;width:260px;background:#fff;border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 10px 25px #0000001a;margin-top:.75rem;z-index:1000;animation:phSlideDown .2s ease}.ph-user-info-section{display:flex;align-items:center;gap:1rem;padding:1.25rem;background:#f8fafc;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.ph-avatar-large{width:48px;height:48px;border-radius:14px;background:linear-gradient(135deg,var(--color-primary),#1a4d8c);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.2rem;flex-shrink:0}.ph-user-details-large{flex:1;min-width:0}.ph-user-name-large{font-weight:700;color:var(--color-text-primary);font-size:.95rem;margin-bottom:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ph-user-email{font-size:.8rem;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis}.ph-dropdown-section{padding:.5rem}.ph-dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;font-size:.9rem;color:var(--color-text-primary);font-weight:500}.ph-dropdown-item:hover{background-color:var(--color-card-hover)}.ph-logout-item{color:#ef4444}.ph-logout-item:hover{background-color:#fef2f2}.ph-item-icon{width:18px;height:18px}.ph-dropdown-divider{height:1px;background:var(--color-border);margin:.25rem .5rem}@keyframes phSlideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1024px){.header{left:0!important;min-height:70px}.ph-container{padding:.75rem 1.5rem}}@media(max-width:768px){.ph-container{padding:.5rem 1rem}.ph-welcome{display:none}.ph-right{gap:.75rem!important}.ph-lang-dropdown,.ph-profile-dropdown{position:fixed;top:70px;right:1rem;left:1rem;width:auto;margin:0}}@media(max-width:480px){.ph-right{gap:.5rem!important}.ph-avatar{width:34px;height:34px;border-radius:10px}.ph-btn{padding:.5rem}}.ph-notification-btn{position:relative;background:#fff!important;padding:12px!important;border-radius:14px!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important;display:flex!important;align-items:center!important;justify-content:center!important;color:var(--color-primary)!important;box-shadow:0 2px 8px #0a2e5d0a!important;border:1px solid rgba(10,46,93,.05)!important;cursor:pointer}.ph-notification-btn:hover{background:linear-gradient(135deg,#0a2e5d08,#0a2e5d0f)!important;box-shadow:0 4px 12px #0a2e5d1f!important;transform:translateY(-2px)!important;border-color:#0a2e5d1a!important}.ph-notification-btn:active{transform:translateY(0)!important;box-shadow:0 2px 8px #0a2e5d14!important}.ph-notification-badge{position:absolute;top:4px;right:4px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:10px;font-weight:800;min-width:20px;height:20px;border-radius:999px;display:flex;align-items:center;justify-content:center;padding:0 5px;border:2.5px solid white;box-shadow:0 2px 8px #ef44444d;animation:notificationPulse 2s ease-in-out infinite}@keyframes notificationPulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.app-layout{display:flex;height:100vh;width:100vw;position:fixed;top:0;left:0;overflow:hidden;background-color:var(--color-bg)}.app-layout-main{flex:1;display:flex;flex-direction:column;min-width:0;transition:all .4s cubic-bezier(.4,0,.2,1);position:relative;background:transparent}.app-layout-content-area{flex:1;overflow-y:auto;background-color:transparent;margin:0;position:relative;border:3px solid var(--color-border);border-radius:24px;padding:20px 30px}.app-layout-content-container{min-height:100%;padding:0}.app-layout-page-wrapper{padding:0;min-height:100%}@media(min-width:1025px){.app-layout-main.sidebar-expanded{margin-left:280px}.app-layout-main.sidebar-collapsed{margin-left:80px}}@media(max-width:1024px){.app-layout{padding-left:0}.app-layout-main{margin-left:0;border-radius:0}.app-layout-main.sidebar-expanded{transform:translate(280px);border-radius:24px 0 0 24px;box-shadow:-5px 0 30px #00000026}.app-layout-main.sidebar-expanded .app-layout-content-area{border-radius:24px 0 0 24px}}.app-layout>:not(.sb-main) *{transition:color .2s ease,background-color .2s ease,border-color .2s ease}.app-layout-content-area::-webkit-scrollbar{width:6px}.app-layout-content-area::-webkit-scrollbar-track{background:var(--color-bg)}.app-layout-content-area::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.app-layout-content-area::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}.app-layout.loading .app-layout-main{opacity:.7;pointer-events:none}@media(prefers-contrast:high){.app-layout-main{border:1px solid var(--color-border)}}@media(prefers-reduced-motion:reduce){.app-layout-main,.app-layout{transition:none}}:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: hsl(6, 78%, 57%);--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-container-width: fit-content;--toastify-toast-width: 320px;--toastify-toast-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-padding: 14px;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-toast-shadow: 0px 4px 12px rgba(0, 0, 0, .1);--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error);--toastify-color-progress-bgo: .2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;width:var(--toastify-container-width);box-sizing:border-box;color:#fff;display:flex;flex-direction:column}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y: 0;position:relative;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;display:flex;flex:1 auto;align-items:center;word-break:break-word}@media only screen and (max-width:480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}.Toastify__toast{--toastify-toast-width: 100%;margin-bottom:0;border-radius:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{margin-inline-end:10px;width:22px;flex-shrink:0;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;position:absolute;top:6px;right:6px;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:1;opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{position:absolute;overflow:hidden;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.db-container{max-width:1400px;margin:0 auto;padding:2rem;animation:fadeIn .3s cubic-bezier(.4,0,.2,1)}@media(max-width:1024px){.db-container{padding:1.5rem}}@media(max-width:768px){.db-container{padding:1rem}}.db-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;gap:1rem}.db-welcome{flex:1}.db-title{font-size:2rem;font-weight:700;color:#1a202c;margin:0 0 .5rem;letter-spacing:-.5px}.db-subtitle{font-size:1rem;color:#718096;margin:0}.db-header-actions{display:flex;align-items:center;gap:.75rem}.db-today-pill{padding:.625rem 1.25rem;background:var(--color-primary);color:#fff;border:none;border-radius:24px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.db-today-pill:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(var(--color-primary-rgb),.4);background:#082544}.db-today-pill:active{transform:translateY(0)}.db-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2.5rem}@media(max-width:1200px){.db-stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.db-stats-grid{grid-template-columns:1fr;gap:1rem}}.db-stat-card{display:flex;align-items:center;gap:1.25rem;background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);animation:slideUp .4s cubic-bezier(.4,0,.2,1) backwards}.db-stat-card:nth-child(1){animation-delay:.05s}.db-stat-card:nth-child(2){animation-delay:.1s}.db-stat-card:nth-child(3){animation-delay:.15s}.db-stat-card:nth-child(4){animation-delay:.2s}.db-stat-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000014;border-color:#cbd5e0}.db-stat-icon-wrapper{width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s}.db-stat-card:hover .db-stat-icon-wrapper{transform:scale(1.08)}.db-stat-info{display:flex;flex-direction:column;gap:.25rem;min-width:0}.db-stat-label{font-size:.875rem;color:#718096;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.db-stat-value{font-size:1.875rem;font-weight:700;color:#1a202c;line-height:1}.db-calendar-nav-horizontal{display:flex;align-items:center;gap:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:24px;padding:1rem 1.25rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000000a}.db-nav-arrow{flex-shrink:0;width:40px;height:40px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;color:#4a5568;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.db-nav-arrow:hover{background:#f7fafc;border-color:#cbd5e0;color:#2d3748;transform:scale(1.05)}.db-nav-arrow:active{transform:scale(.95)}.db-days-container{display:flex;gap:.5rem;flex:1;justify-content:space-around;overflow-x:auto;scrollbar-width:none}.db-days-container::-webkit-scrollbar{display:none}.db-day-item{position:relative;display:flex;flex-direction:column;align-items:center;gap:.375rem;padding:.75rem 1rem;border-radius:16px;background:transparent;border:1px solid transparent;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);min-width:70px}.db-day-label{font-size:.75rem;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px}.db-day-date{font-size:1.25rem;font-weight:700;color:#2d3748}.db-day-item:hover{background:#f7fafc;border-color:#e2e8f0}.db-day-active{background:var(--color-primary);border-color:transparent;box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.db-day-active:hover{background:#082544}.db-day-active .db-day-label,.db-day-active .db-day-date{color:#fff}.db-day-is-today:not(.db-day-active){border-color:var(--color-primary);background:rgba(var(--color-primary-rgb),.1)}.db-day-is-today:not(.db-day-active) .db-day-label{color:var(--color-primary)}.db-day-is-today:not(.db-day-active) .db-day-date{color:var(--color-primary);font-weight:800}.db-today-dot{position:absolute;bottom:6px;width:6px;height:6px;border-radius:50%;background:#fff}.db-sessions-section-full{margin-bottom:2rem}.db-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.db-section-title{font-size:1.5rem;font-weight:700;color:#1a202c;margin:0;display:flex;align-items:center;gap:.75rem}.db-count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 .75rem;background:var(--color-primary);color:#fff;border-radius:16px;font-size:.875rem;font-weight:600}.db-date-indicator{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;font-size:.875rem;color:#4a5568;font-weight:500}.db-date-indicator svg{color:#718096}.db-sessions-grid{display:grid;gap:1.25rem;grid-template-columns:repeat(3,1fr)}@media(max-width:1200px){.db-sessions-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.db-sessions-grid{grid-template-columns:1fr}}.db-loading-wrap{display:flex;justify-content:center;align-items:center;padding:4rem 1rem}.db-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:#667eea;border-radius:50%;animation:spin .8s linear infinite}.db-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;background:#fff;border:1px solid #e2e8f0;border-radius:24px;animation:fadeIn .4s cubic-bezier(.4,0,.2,1)}.db-empty-art{width:120px;height:120px;border-radius:50%;background:rgba(var(--color-primary-rgb),.1);display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;color:var(--color-primary)}.db-empty-state h4{font-size:1.5rem;font-weight:700;color:#1a202c;margin:0 0 .5rem}.db-empty-state p{font-size:1rem;color:#718096;margin:0}@media(max-width:768px){.db-header-row{flex-direction:column;align-items:flex-start}.db-title{font-size:1.5rem}.db-calendar-nav-horizontal{padding:.75rem 1rem}.db-nav-arrow{width:36px;height:36px}.db-day-item{min-width:60px;padding:.625rem .75rem}.db-day-date{font-size:1.125rem}.db-section-header{flex-direction:column;align-items:flex-start}.db-section-title{font-size:1.25rem}}.sc-card{background:#fff;border:1px solid #e2e8f0;border-radius:20px;padding:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1);animation:scSlideUp .4s cubic-bezier(.4,0,.2,1) backwards;position:relative;overflow:hidden}.sc-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--color-primary);opacity:0;transition:opacity .3s}.sc-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px #00000014;border-color:#cbd5e0}.sc-card:hover:before{opacity:1}.sc-break{background:rgba(var(--color-primary-rgb),.05);border:1px dashed #cbd5e0}.sc-break:before{display:none}.sc-break:hover{transform:none;box-shadow:none;border-color:#cbd5e0}.sc-break-content{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 0}.sc-break-icon{width:40px;height:40px;border-radius:12px;background:rgba(var(--color-primary-rgb),.1);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.sc-break-text{font-size:1rem;font-weight:600;color:var(--color-primary);letter-spacing:.5px}.sc-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1.25rem;padding-bottom:1.25rem;border-bottom:1px solid #f1f5f9}.sc-subject-row{display:flex;align-items:flex-start;gap:1rem;flex:1;min-width:0}.sc-subject-icon{width:48px;height:48px;border-radius:14px;background:#3b82f61a;display:flex;align-items:center;justify-content:center;color:#3b82f6;flex-shrink:0;transition:transform .2s}.sc-card:hover .sc-subject-icon{transform:scale(1.08)}.sc-subject-info{flex:1;min-width:0}.sc-subject-name{font-size:1.125rem;font-weight:700;color:#1a202c;margin:0 0 .25rem;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.sc-topic{font-size:.875rem;color:#718096;margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.sc-mode-badge{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;border-radius:12px;font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0;transition:all .2s}.sc-mode-online{background:#10b9811a;color:#059669;border:1px solid rgba(16,185,129,.2)}.sc-mode-offline{background:#f59e0b1a;color:#d97706;border:1px solid rgba(245,158,11,.2)}.sc-time-section{margin-bottom:1.25rem;padding:1rem;background:#f8fafc;border-radius:12px}.sc-time-item{display:flex;align-items:center;gap:.625rem;color:#4a5568}.sc-time-item svg{color:#718096;flex-shrink:0}.sc-time-value{font-size:.9375rem;font-weight:600;color:#2d3748}.sc-footer{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.sc-teacher{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.sc-teacher-avatar{width:40px;height:40px;border-radius:12px;background:#8b5cf61a;display:flex;align-items:center;justify-content:center;color:#8b5cf6;flex-shrink:0}.sc-teacher-name{font-size:.9375rem;font-weight:600;color:#4a5568;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sc-join-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:var(--color-primary);color:#fff;border:none;border-radius:12px;font-size:.875rem;font-weight:600;text-decoration:none;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.25);flex-shrink:0}.sc-join-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(var(--color-primary-rgb),.35);background:#082544}.sc-join-btn:active{transform:translateY(0)}.sc-join-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.sc-join-btn:disabled:hover{transform:none;box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.25)}.sc-spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes scSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.sc-card{padding:1.25rem}.sc-header{flex-direction:column}.sc-mode-badge{align-self:flex-start}.sc-subject-name{font-size:1rem}.sc-footer{flex-direction:column;align-items:stretch}.sc-join-btn{justify-content:center}}.chart-heading{font-family:Rubik,sans-serif;color:#023047;text-transform:uppercase;font-size:24px;text-align:center}.chart-container{width:200px}.programming-stats{display:flex;align-items:center;gap:24px;margin:0 auto 20px;border-radius:20px;padding:10px 32px;color:#023047;transition:all .4s ease;width:100%;justify-content:center}.programming-stats .title{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}.programming-stats .title .title-name{font-size:var(--font-size-text-primary);color:var(--color-text-primary);font-weight:700}.programming-stats .title .title-count-container{display:flex;gap:5px;justify-content:center;align-items:center;background-color:var(--color-success-bg);width:fit-content;padding:3px 10px;border-radius:var(--radius-md);font-weight:500}.programming-stats .details{display:flex;flex-direction:column;gap:10px}.details .stats-container{display:flex;gap:10px}.stats-container .icon-container{display:flex;justify-content:center;align-items:center;border-radius:var(--radius-md);height:40px;width:40px}.stats-container .details-container{display:flex;flex-direction:column}.details-container .stat-name{font-size:var(--font-size-text-primary);color:var(--color-text-primary);font-weight:600}.details-container .stat-count{font-size:var(--font-size-text-secondary);color:var(--color-text-secondary);font-weight:400}@media(max-width:640px){.programming-stats{flex-direction:column}.programming-stats .details{flex-direction:row}}:root{--login-primary: #0a2e5d;--login-accent: #e0591e;--login-text: #1e293b;--login-text-muted: #64748b;--login-bg-start: #0f172a;--login-bg-end: #1e293b;--glass-bg: rgba(255, 255, 255, .75);--glass-border: rgba(255, 255, 255, .5);--glass-shadow: 0 8px 32px 0 rgba(0, 0, 0, .2)}.login-page-wrapper{min-height:100vh;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--login-bg-start) 0%,var(--login-bg-end) 100%);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;padding:2rem;box-sizing:border-box}.login-header-float{position:absolute;top:0;left:0;width:100%;z-index:100;padding:1.5rem 3rem;box-sizing:border-box}.login-header-content{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.login-logo{font-size:1.5rem;font-weight:800;color:#fff;letter-spacing:-.02em}.login-lang-container{position:relative}.login-lang-selector{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:12px;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.login-lang-selector:hover,.login-lang-selector.active{background:#fff3}.lang-chevron{color:#ffffffb3;transition:transform .2s ease}.lang-chevron.rotate{transform:rotate(180deg)}.lang-flag{width:24px;height:18px;object-fit:cover;border-radius:4px}.lang-name{color:#fff;font-weight:600;font-size:.9rem}.login-lang-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:180px;background:#1e293bf2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:12px;box-shadow:0 4px 20px #0000004d;overflow:hidden;animation:slideDown .2s ease-out forwards}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.lang-option{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;cursor:pointer;transition:background .2s ease;border-bottom:1px solid rgba(255,255,255,.05)}.lang-option:last-child{border-bottom:none}.lang-option:hover{background:#ffffff1a}.lang-option.selected{background:#ffffff0d}.lang-flag-small{width:20px;height:15px;object-fit:cover;border-radius:2px}.lang-name-option{flex:1;color:#fff;font-size:.9rem;font-weight:500}.lang-check{color:#3b82f6}.login-bg-shapes{position:absolute;top:0;left:0;width:100%;height:100%;z-index:1;pointer-events:none}.shape{position:absolute;border-radius:50%;filter:blur(80px);opacity:.15;animation:float 20s infinite alternate}.shape-1{width:500px;height:500px;background:var(--login-primary);top:-100px;left:-100px}.shape-2{width:400px;height:400px;background:var(--login-accent);bottom:-50px;right:-50px;animation-delay:-5s}.shape-3{width:300px;height:300px;background:#3b82f6;top:40%;right:15%;animation-delay:-10s}@keyframes float{0%{transform:translate(0) scale(1)}to{transform:translate(100px,50px) scale(1.1)}}.login-container-new{position:relative;z-index:10;width:100%;max-width:460px;animation:loginAppear .8s cubic-bezier(.16,1,.3,1)}@keyframes loginAppear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-card{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-radius:24px;border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);padding:3rem 2.5rem;display:flex;flex-direction:column;gap:2rem}.login-header-new{text-align:center}.login-welcome{font-size:1.5rem;font-weight:700;color:var(--login-text);margin-bottom:.5rem}.login-subtitle{font-size:.9375rem;color:var(--login-text-muted)}.login-form-new{display:flex;flex-direction:column;gap:1.5rem}.form-group-new{display:flex;flex-direction:column;gap:.75rem}.form-label-new{font-size:.875rem;font-weight:600;color:var(--login-text);display:flex;align-items:center;gap:.5rem}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1.25rem;color:var(--login-text-muted);pointer-events:none;transition:color .3s ease}.form-input-new{width:100%;padding:1rem 1.25rem 1rem 3.5rem;background:#ffffff80;border:2px solid transparent;border-radius:16px;font-size:1rem;color:var(--login-text);transition:all .3s ease}.form-input-new::placeholder{color:var(--login-text-muted);opacity:.6}.form-input-new:focus{outline:none;background:#fff;border-color:var(--login-primary);box-shadow:0 0 0 4px #0a2e5d1a}.form-input-new:focus+.input-icon,.input-wrapper:focus-within .input-icon{color:var(--login-primary)}.form-input-new:disabled{opacity:.6;cursor:not-allowed}.password-toggle-new{position:absolute;right:1rem;background:none;border:none;color:var(--login-text-muted);cursor:pointer;padding:.5rem;border-radius:10px;display:flex;align-items:center;justify-content:center;transition:all .2s}.password-toggle-new:hover:not(:disabled){background:#0a2e5d0d;color:var(--login-primary)}.password-toggle-new:disabled{opacity:.5;cursor:not-allowed}.form-options{display:flex;justify-content:space-between;align-items:center;font-size:.875rem}.remember-me-new{display:flex;align-items:center;gap:.625rem;cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--login-text);font-weight:500;transition:opacity .2s}.remember-me-new:hover{opacity:.8}.custom-checkbox{width:20px;height:20px;border:2px solid #cbd5e1;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .2s;background:#fff}.remember-me-new:hover .custom-checkbox{border-color:var(--login-primary)}.remember-me-new.checked .custom-checkbox{background:var(--login-primary);border-color:var(--login-primary)}.checkbox-icon{color:#fff;opacity:0;transform:scale(.5);transition:all .2s cubic-bezier(.12,.4,.29,1.46)}.remember-me-new.checked .checkbox-icon{opacity:1;transform:scale(1)}.forgot-btn{background:none;border:none;color:var(--login-primary);font-weight:600;cursor:pointer;transition:color .2s;padding:0}.forgot-btn:hover:not(:disabled){color:var(--login-accent);text-decoration:underline}.forgot-btn:disabled{opacity:.5;cursor:not-allowed}.login-error-msg{background:#fef2f2;border:1px solid #fee2e2;color:#ef4444;padding:.75rem 1rem;border-radius:12px;font-size:.875rem;display:flex;align-items:center;gap:.5rem;animation:shake .4s cubic-bezier(.36,.07,.19,.97) both}@keyframes shake{10%,90%{transform:translate3d(-1px,0,0)}20%,80%{transform:translate3d(2px,0,0)}30%,50%,70%{transform:translate3d(-4px,0,0)}40%,60%{transform:translate3d(4px,0,0)}}.login-submit-btn{width:100%;padding:1rem;background:linear-gradient(135deg,var(--login-primary) 0%,#1a4d8c 100%);color:#fff;border:none;border-radius:16px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:.75rem;box-shadow:0 4px 12px #0a2e5d33}.login-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 20px #0a2e5d4d}.login-submit-btn:active:not(:disabled){transform:translateY(0)}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed}.login-spinner{animation:spin 1s linear infinite}.login-footer-info{text-align:center;font-size:.8125rem;color:var(--login-text-muted);margin-top:.5rem}.forgot-password-buttons{display:flex;gap:12px;margin-top:.5rem}.auth-button.secondary{flex:1;padding:1rem;background:#f3f4f6;color:#374151;border:none;border-radius:16px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.auth-button.secondary:hover:not(:disabled){background:#e5e7eb}.auth-button.secondary:disabled{opacity:.5;cursor:not-allowed}.login-submit-btn.primary{flex:1}.forgot-password-success{text-align:center;margin:1.5rem 0}.success-icon{width:64px;height:64px;background:#10b981;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px;font-weight:700;margin:0 auto 1.5rem}.success-message{color:#10b981;font-weight:600;font-size:1rem;margin:0 0 .5rem}.success-note{color:#6b7280;font-size:.875rem;margin:0 0 1.5rem;line-height:1.4}@media(max-width:1200px){.login-card{margin-top:6rem}}@media(max-width:768px){.login-header-float{padding:1.25rem 2rem}.login-header-content{flex-direction:column;gap:1rem;text-align:center}}@media(max-width:480px){.login-page-wrapper{padding:1rem}.login-card{padding:2.5rem 1.5rem}.login-logo{font-size:1.25rem}.login-welcome{font-size:1.35rem}.login-header-float{padding:1rem 1.5rem}.shape-1,.shape-2,.shape-3{filter:blur(60px)}}html,body{margin:0;padding:0;overflow-x:hidden}@media(max-width:480px)and (max-height:700px){.login-card{margin-top:7rem}}.library-container{width:100%;display:flex;flex-direction:column;gap:1.5rem;height:100%}.library-content{display:flex;gap:1.5rem;height:100%;overflow:hidden}.library-content.split-view .library-list-section{flex:0 0 50%;overflow-y:auto}.library-list-section{flex:1;display:flex;flex-direction:column;gap:1.5rem}.library-detail-section{flex:0 0 50%;background:#fff;border-radius:12px;border:1px solid #e2e8f0;display:flex;flex-direction:column;overflow:hidden;max-height:100%}.library-detail-header{padding:20px 24px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;background:#fff;position:sticky;top:0;z-index:10;flex-shrink:0}.library-detail-header h3{margin:0;font-size:16px;font-weight:700;color:#0f172a}.library-detail-content{flex:1;overflow-y:auto;background:#f8fafc}.library-table tbody tr.selected{background:rgba(var(--color-primary-rgb, 30, 64, 175),.08);border-left:3px solid var(--color-primary, #1e40af)}.library-table tbody tr{cursor:pointer;transition:background-color .2s}.library-table tbody tr:hover{background:rgba(var(--color-primary-rgb, 30, 64, 175),.04)}.library-header{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}.library-title-section{display:flex;align-items:center;gap:.75rem}.library-title{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.library-count{display:inline-flex;align-items:center;padding:.375rem .75rem;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);border-radius:20px;font-size:.875rem;font-weight:600}.library-search-section{display:flex;gap:.75rem;align-items:center;flex:1;max-width:600px}.library-search-box{position:relative;flex:1;min-width:200px}.library-search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.library-search-box input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid #e2e8f0;border-radius:10px;font-size:.875rem;color:#1e293b;background:#fff;transition:all .2s cubic-bezier(.4,0,.2,1)}.library-search-box input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.library-search-box input::placeholder{color:#94a3b8}.library-category-filter{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:10px;font-size:.875rem;font-weight:500;color:#475569;background:#fff;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);min-width:150px}.library-category-filter:hover{border-color:var(--color-primary)}.library-category-filter:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.library-table-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.library-table{width:100%;border-collapse:collapse}.library-table thead{background:#f8fafc;border-bottom:1px solid #e2e8f0}.library-table thead th{padding:1rem 1.25rem;text-align:left;font-size:.75rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.library-action-header{text-align:center!important}.library-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .2s cubic-bezier(.4,0,.2,1)}.library-table tbody tr:last-child{border-bottom:none}.library-table tbody tr:hover{background:#f8fafc}.library-table tbody td{padding:1.25rem;font-size:.875rem;color:#475569;vertical-align:middle}.library-title-cell{display:flex;align-items:center;gap:.75rem}.library-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.library-title-text{font-weight:600;color:#1e293b;line-height:1.4}.library-type-cell{display:flex;align-items:center;gap:.5rem}.library-visibility-badge{display:inline-flex;padding:.375rem .75rem;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);border-radius:6px;font-size:.8125rem;font-weight:600;white-space:nowrap}.library-tags-cell{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.library-tag{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:#f1f5f9;color:#475569;border-radius:6px;font-size:.8125rem;font-weight:500;white-space:nowrap}.library-tag svg{flex-shrink:0}.library-actions-cell{display:flex;gap:.5rem;justify-content:center;align-items:center}.library-open-btn,.library-download-btn{width:40px;height:40px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.library-open-btn:hover,.library-download-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:scale(1.05)}@media(max-width:1024px){.library-header{flex-direction:column;align-items:stretch}.library-search-section{max-width:none}}@media(max-width:768px){.library-title{font-size:1.25rem}.library-table thead th{padding:.75rem 1rem;font-size:.6875rem}.library-table tbody td{padding:1rem}.library-actions-cell{flex-wrap:wrap}.library-tags-cell{max-width:200px}}@media(max-width:640px){.library-title-section{flex-direction:column;align-items:flex-start}.library-search-section{flex-direction:column}.library-category-filter{width:100%}.library-table{font-size:.8125rem}.library-title-cell{flex-direction:column;align-items:flex-start}.library-tags-cell{max-width:150px}}.resource-modal-overlay{position:fixed;inset:0;background:#0f172abf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:20px;z-index:2000;animation:fadeIn .2s ease-out}.resource-modal-content{background:#fff;width:100%;max-width:900px;height:auto;max-height:85vh;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.resource-modal-header{padding:20px 32px;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.resource-modal-header h2{margin:0;font-size:18px;font-weight:700;color:#0f172a;display:flex;align-items:center;gap:10px}.resource-modal-close{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:none;background:#f8fafc;color:#64748b;cursor:pointer;transition:all .2s}.resource-modal-close:hover{background:#fee2e2;color:#ef4444;transform:rotate(90deg)}.resource-modal-body{flex:1;overflow-y:auto;padding:0;background:#f8fafc;display:flex;flex-direction:column}.resource-modern-header{margin-bottom:0;padding:32px 32px 24px;background:#fff;position:sticky;top:0;z-index:10;border-bottom:1px solid #e2e8f0}.resource-badges{display:flex;gap:8px;margin-bottom:12px;flex-wrap:wrap}.resource-pill{padding:4px 12px;border-radius:16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;display:inline-flex;align-items:center;gap:6px}.resource-pill.visibility-pill{background:#dbeafe;color:#1e40af}.resource-pill.tag-pill{background:#f1f5f9;color:#475569}.resource-title-modern{margin:0;font-size:24px;font-weight:800;color:var(--color-primary, #1e40af);line-height:1.3}.resource-modern-grid{display:grid;gap:16px;grid-template-columns:1fr;padding:24px 32px 32px}.resource-description-card{background:#fff;border-radius:12px;padding:20px;border:1px solid #e2e8f0;margin:0}.resource-files-card{background:#fff;border-radius:12px;padding:20px;border:1px solid #e2e8f0}.files-list-modern{display:flex;flex-direction:column;gap:8px}.file-item-modern{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#f8fafc;border-radius:8px;transition:all .2s}.file-item-modern:hover{background:#f1f5f9}.file-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.file-actions{display:flex;gap:4px}.resource-associations-card{background:#fff;border-radius:12px;padding:20px;border:1px solid #e2e8f0}.associations-grid{display:flex;flex-direction:column;gap:16px}.association-item{display:flex;flex-direction:column;gap:8px}.association-label{font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.association-values{display:flex;flex-wrap:wrap;gap:8px}.association-badge{padding:6px 12px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;font-size:12px;font-weight:600;color:#475569}@media(max-width:768px){.resource-modal-content{max-width:100%;max-height:100vh;border-radius:0}.resource-modal-body{padding:20px}.resource-title-modern{font-size:20px}}.file-preview-overlay{position:fixed;inset:0;background:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:3000;padding:20px;animation:fadeIn .2s ease-out}.file-preview-modal{background:#fff;width:100%;max-width:1200px;height:90vh;border-radius:16px;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s cubic-bezier(.16,1,.3,1);box-shadow:0 25px 50px -12px #00000080}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.file-preview-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:#f8fafc;border-bottom:1px solid #e2e8f0}.file-preview-title{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.file-name{font-size:16px;font-weight:600;color:var(--color-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-type-badge{padding:4px 10px;background:var(--color-primary);color:#fff;border-radius:6px;font-size:11px;font-weight:700;letter-spacing:.5px}.file-preview-actions{display:flex;gap:8px}.preview-action-btn{width:36px;height:36px;border:none;background:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;color:#64748b}.preview-action-btn:hover{background:#e2e8f0;color:var(--color-primary)}.preview-close-btn:hover{background:#fee2e2;color:#ef4444}.file-preview-body{flex:1;overflow:hidden;background:#f1f5f9;display:flex;align-items:center;justify-content:center}.preview-content-wrapper{width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:20px}.preview-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a}.preview-iframe{width:100%;height:100%;border:none;border-radius:8px;background:#fff}.preview-video{max-width:100%;max-height:100%;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a}.preview-no-support{background:#fff;border-radius:8px;padding:40px}.no-preview-message{text-align:center;display:flex;flex-direction:column;align-items:center;gap:20px}.no-preview-message p{font-size:16px;color:#64748b;margin:0}.preview-download-btn-large{display:flex;align-items:center;gap:10px;padding:12px 24px;background:var(--color-primary);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.preview-download-btn-large:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a}@media(max-width:768px){.file-preview-modal{height:100vh;max-width:100%;border-radius:0}.file-preview-header{padding:12px 16px}.file-name{font-size:14px}.preview-content-wrapper{padding:10px}}.schedule-analytics-container{display:flex;gap:15px;margin-top:20px}.analytics-section-classes{max-width:60%;padding:15px;border-radius:var(--radius-md)}.analytics-card-classes-content{display:flex;align-items:center;gap:15px}.classes-today{display:flex;flex-direction:column;background-color:var(--color-error-bg);padding:15px;border-radius:var(--radius-sm)}.card-icon{display:flex;align-items:center;justify-content:center;height:35px;width:35px;font-size:24px;color:var(--color-text-inverse);background-color:var(--color-error);margin-bottom:8px;padding:5px;border-radius:50%}.card-count{font-size:28px;font-weight:700;color:var(--color-text-primary);margin-bottom:8px}.card-main{font-size:14px;color:var(--color-text-primary);font-weight:500}.card-sub{font-size:10px;color:#297eb3;font-weight:400;margin-top:4px}.analytics-section-attendance{display:flex;flex-grow:1;padding:15px;border-radius:var(--radius-md)}.schedule-timetable-container{margin-top:15px;padding:20px;border-radius:12px;background:#fff;border:1px solid #e2e8f0;transition:opacity .3s cubic-bezier(.4,0,.2,1)}.schedule-timetable-container.updating{opacity:.6;pointer-events:none}.schedule-timetable-container.updating .schedule-table-wrapper:after{content:"";position:absolute;inset:0;background:#ffffff80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:12px;animation:pulse 1.5s ease-in-out infinite}.schedule-timetable-title{font-weight:600;color:#1e293b;font-size:1.125rem;margin-bottom:1.5rem}.schedule-tab-header{display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:1.5rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:1.5rem}.schedule-week-nav-btn{width:44px;height:44px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0}.schedule-week-nav-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:scale(1.05)}.schedule-week-nav-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.schedule-week-info{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem}.schedule-week-label{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.schedule-week-dates{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:700;color:#1e293b}.schedule-week-dates svg{color:var(--color-primary);flex-shrink:0}.schedule-table-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow-x:auto}.schedule-timetable{width:100%;border-collapse:collapse;min-width:1200px}.schedule-timetable thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.schedule-timetable thead th{padding:1rem;text-align:center;font-size:.75rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em;vertical-align:middle}.schedule-time-header{text-align:left!important;position:sticky;left:0;background:#f8fafc;z-index:10;border-right:2px solid #e2e8f0;display:flex;align-items:center;gap:.5rem;justify-content:center}.schedule-day-header{min-width:150px}.day-short{font-size:.75rem;font-weight:500;color:#94a3b8;text-transform:none}.schedule-timetable tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .2s cubic-bezier(.4,0,.2,1)}.schedule-timetable tbody tr:last-child{border-bottom:none}.schedule-timetable tbody tr:hover{background:#f8fafc}.schedule-timetable tbody td{padding:1rem;font-size:.875rem;color:#475569;vertical-align:top;text-align:center}.schedule-time-cell{position:sticky;left:0;background:#fff;z-index:5;border-right:2px solid #f1f5f9;text-align:left!important;font-weight:600;color:#475569}.schedule-timetable tbody tr:hover .schedule-time-cell{background:#f8fafc}.schedule-session-cell{padding:.75rem!important}.schedule-break-cell{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fbbf24}.schedule-no-session-cell{background:#f1f5f9;border:1px solid #e2e8f0}.schedule-empty-cell{background:#fafafa}@media(max-width:1024px){.schedule-timetable-container{padding:1rem}.schedule-timetable{min-width:1000px}}@media(max-width:768px){.schedule-timetable-container{padding:15px}.schedule-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch}.schedule-timetable thead th{padding:.75rem .5rem;font-size:.6875rem}.schedule-timetable tbody td{padding:.75rem .5rem}.session-card{padding:.75rem;min-height:100px}.session-subject{font-size:.875rem}.session-teacher{font-size:.75rem}.day-name{font-size:.8125rem}.day-short{font-size:.6875rem}}color: var(--color-text-primary); } .schedule-timetable .schedule-session-cell .teacher-name{font-size:var(--font-size-tiny);color:var(--color-text-secondary)}.courses-container{font-family:var(--font-family);background-color:var(--color-bg);min-height:100vh;padding:2rem;color:var(--color-text-primary);transition:background-color .3s ease;max-width:1400px;margin:0 auto;animation:fadeIn .3s cubic-bezier(.4,0,.2,1)}.courses-header-section{background:#fff;padding:1.5rem 2rem;border-radius:20px;margin-bottom:2rem;box-shadow:0 4px 20px #0a2e5d0d;border:1px solid rgba(10,46,93,.05)}.courses-header-content{display:flex;justify-content:space-between;align-items:center;width:100%}.courses-header-main{display:flex;flex-direction:column;gap:.25rem}.courses-page-title{font-size:1.75rem;font-weight:800;color:var(--color-primary);margin:0;letter-spacing:-.02em}.courses-breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#64748b;font-weight:500}.courses-breadcrumb .breadcrumb-item{transition:color .2s ease;cursor:pointer}.courses-breadcrumb .breadcrumb-item:hover{color:var(--color-primary)}.courses-breadcrumb .breadcrumb-item.active{color:var(--color-accent);font-weight:700}.courses-breadcrumb .breadcrumb-separator{color:#cbd5e1}.courses-filters-section{background:#fff;border-radius:20px;padding:1.25rem 2rem;display:flex;justify-content:space-between;gap:1.25rem;align-items:center;box-shadow:0 4px 15px #0a2e5d08;margin-bottom:2rem;border:1px solid rgba(10,46,93,.05)}.courses-search-box{max-width:300px;position:relative;flex:1}.courses-search-icon{position:absolute;left:1.25rem;top:50%;transform:translateY(-50%);color:#94a3b8;transition:color .3s ease;pointer-events:none}.courses-search-input{width:100%;padding:14px 20px 14px 3.5rem;border:2px solid #f1f5f9;border-radius:28px;font-size:15px;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);background:#f8fafc;color:var(--color-primary)}.courses-search-input:focus{outline:none;border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 4px #0a2e5d14}.courses-search-input:focus~.courses-search-icon{color:var(--color-primary)}.courses-search-input::placeholder{color:#94a3b8;font-weight:500}.courses-tabs{display:flex;padding:0 1.5rem;background:#f8fafc;overflow-x:auto;scrollbar-width:none;border-radius:16px}.courses-tabs::-webkit-scrollbar{display:none}.tab-button{display:flex;align-items:center;gap:8px;padding:1.25rem 1.5rem;background:none;border:none;border-bottom:3px solid transparent;color:#64748b;font-weight:700;font-size:14px;cursor:pointer;transition:all .3s ease;white-space:nowrap;position:relative}.tab-button:hover{color:var(--color-primary);background:#0a2e5d05;transform:none}.tab-button.active{color:var(--color-primary);border-bottom-color:var(--color-accent);background:#fff;box-shadow:none}.courses-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 0;gap:1rem}.courses-spinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.courses-loading p{color:var(--color-text-secondary);font-size:1rem;font-weight:500}.no-courses-container{background:#fff;border-radius:20px;padding:4rem 2rem;text-align:center;box-shadow:0 4px 15px #0a2e5d08;border:1px solid rgba(10,46,93,.05)}.no-courses-text{color:var(--color-text-secondary);font-size:1rem;font-weight:500;margin:0}.courses-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.75rem}@media(max-width:1200px){.courses-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.courses-container{padding:1rem}.courses-header-section{padding:1.25rem 1.5rem;border-radius:16px}.courses-page-title{font-size:1.375rem}.courses-filters-section{flex-direction:column;align-items:stretch;padding:1rem 1.5rem}.courses-search-box{max-width:100%;width:100%}.courses-tabs{width:100%;justify-content:flex-start;padding:0}.courses-grid{grid-template-columns:1fr;gap:1.25rem}}@media(max-width:640px){.courses-breadcrumb{display:none}.courses-page-title{font-size:1.25rem}.courses-search-input{padding:12px 16px 12px 3rem;font-size:14px}.courses-search-icon{left:1rem}.tab-button{padding:1rem 1.25rem;font-size:.8125rem}}@media(max-width:480px){.courses-header-section,.courses-filters-section{padding:1rem}.tab-button{padding:.75rem 1rem;font-size:.75rem}}.cc-card{background:#fff;border-radius:20px;overflow:hidden;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:1px solid #e2e8f0;box-shadow:0 4px 12px #0000000a;height:100%;display:flex;flex-direction:column}.cc-card:hover{transform:translateY(-6px);box-shadow:0 12px 28px #0000001f;border-color:var(--color-primary)}.cc-banner{height:140px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-accent) 100%);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.cc-banner-pattern{position:absolute;inset:0;background-image:radial-gradient(circle at 20% 50%,rgba(255,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(255,255,255,.1) 0%,transparent 50%);opacity:.6}.cc-banner-content{position:relative;z-index:1}.cc-banner-text{font-size:3rem;font-weight:800;color:#fff;letter-spacing:.05em;text-shadow:0 2px 8px rgba(0,0,0,.1)}.cc-level-badge{position:absolute;top:1rem;right:1rem;display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 12px #00000026;z-index:2}.cc-level-beginner{background:#22c55ee6;color:#fff}.cc-level-intermediate{background:#f59e0be6;color:#fff}.cc-level-master{background:#ef4444e6;color:#fff}.cc-level-default{background:#64748be6;color:#fff}.cc-content{padding:1.5rem;flex:1;display:flex;flex-direction:column;gap:1rem}.cc-category{display:inline-block;width:fit-content;padding:.375rem .875rem;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);border-radius:8px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.cc-title{font-size:1.125rem;font-weight:700;color:#1a202c;margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cc-description{font-size:.875rem;color:#718096;line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1}.cc-meta{display:flex;gap:1rem;padding:.75rem 0;border-top:1px solid #f1f5f9;border-bottom:1px solid #f1f5f9}.cc-meta-item{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#64748b;font-weight:500}.cc-meta-item svg{color:#94a3b8;flex-shrink:0}.cc-progress-section{margin-top:auto}.cc-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.cc-progress-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#475569;font-weight:600}.cc-progress-label svg{color:var(--color-primary)}.cc-progress-percentage{font-size:1.125rem;font-weight:700;color:var(--color-primary)}.cc-progress-bar{height:8px;background:#f1f5f9;border-radius:8px;overflow:hidden;position:relative;margin-bottom:.5rem}.cc-progress-fill{height:100%;background:linear-gradient(90deg,var(--color-accent) 0%,var(--color-primary) 100%);border-radius:8px;transition:width .6s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.cc-progress-shimmer{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.3) 50%,transparent 100%);animation:shimmer 2s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.cc-progress-text{font-size:.75rem;color:#94a3b8;font-weight:500;text-align:right}@media(max-width:768px){.cc-banner{height:120px}.cc-banner-text{font-size:2.5rem}.cc-content{padding:1.25rem}.cc-title{font-size:1rem}.cc-level-badge{top:.75rem;right:.75rem;padding:.375rem .75rem;font-size:.6875rem}}.grades-container{width:100%;display:flex;flex-direction:column;gap:1.5rem}.grades-title-section{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem}.grades-title{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.grades-count{display:inline-flex;align-items:center;padding:.375rem .75rem;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);border-radius:20px;font-size:.875rem;font-weight:600}.grades-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:1.5rem}.grades-stat-card{display:flex;align-items:flex-start;gap:1rem;padding:1.5rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px;transition:all .2s cubic-bezier(.4,0,.2,1)}.grades-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.stat-card-icon-box{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-card-content{display:flex;flex-direction:column;gap:.375rem;flex:1}.stat-card-label{font-size:.75rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em}.stat-card-value{font-size:1.5rem;font-weight:700;color:#1e293b;line-height:1.2}.grades-controls-section{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.grades-search-box{position:relative;flex:1;min-width:200px;max-width:400px}.grades-search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.grades-search-box input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid #e2e8f0;border-radius:10px;font-size:.875rem;color:#1e293b;background:#fff;transition:all .2s cubic-bezier(.4,0,.2,1)}.grades-search-box input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.grades-search-box input::placeholder{color:#94a3b8}.grades-filter-select{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:10px;font-size:.875rem;font-weight:500;color:#475569;background:#fff;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);min-width:150px}.grades-filter-select:hover{border-color:var(--color-primary)}.grades-filter-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.grades-table-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.grades-table{width:100%;border-collapse:collapse}.grades-table thead{background:#f8fafc;border-bottom:1px solid #e2e8f0}.grades-table thead th{padding:1rem 1.25rem;text-align:left;font-size:.75rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.grades-actions-header{text-align:center!important}.grades-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .2s cubic-bezier(.4,0,.2,1)}.grades-table tbody tr:last-child{border-bottom:none}.grades-table tbody tr:hover{background:#f8fafc}.grades-table tbody td{padding:1.25rem;font-size:.875rem;color:#475569;vertical-align:middle}.grades-title-cell{display:flex;align-items:center;gap:.75rem}.grades-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.grades-title-text{font-weight:600;color:#1e293b;line-height:1.4}.grades-description-cell{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#64748b}.grades-type-badge{display:inline-flex;padding:.375rem .75rem;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);border-radius:6px;font-size:.8125rem;font-weight:600;white-space:nowrap;text-transform:capitalize}.grades-status-badge{display:inline-flex;padding:.375rem .75rem;border-radius:6px;font-size:.8125rem;font-weight:600;white-space:nowrap;text-transform:capitalize}.grades-status-badge.active{background:#dcfce7;color:#16a34a}.grades-status-badge.closed{background:#fee2e2;color:#dc2626}.grades-status-badge.graded{background:#dbeafe;color:#2563eb}.grades-score-cell{text-align:center}.grades-score-value{display:inline-flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 12px;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);color:#fff;border-radius:10px;font-size:16px;font-weight:700;box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.25)}.grades-actions{display:flex;gap:.5rem;justify-content:center;align-items:center}.grades-action-btn{width:40px;height:40px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.grades-comments-btn:hover,.grades-chat-btn:hover,.grades-attachments-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:scale(1.05)}@media(max-width:1024px){.grades-stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.grades-controls-section{flex-direction:column;align-items:stretch}.grades-search-box{max-width:none}.grades-filter-select{width:100%}}@media(max-width:768px){.grades-title{font-size:1.25rem}.grades-stats-grid{grid-template-columns:1fr}.stat-item-value{font-size:1.5rem}.grades-table thead th{padding:.75rem 1rem;font-size:.6875rem}.grades-table tbody td{padding:1rem}.grades-title-text{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.grades-description-cell{max-width:150px}}@media(max-width:640px){.grades-title-section{flex-direction:column;align-items:flex-start}.grades-table-wrapper{overflow-x:auto}.grades-table{min-width:900px}}.attachment-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.attachment-modal-content{background:var(--color-card);min-width:640px;max-width:90%;max-height:80vh;border-radius:12px;box-shadow:0 20px 40px #00000026;display:flex;flex-direction:column;animation:modalFadeIn .2s ease-out}.attachment-modal-header{padding:16px 20px;font-size:18px;font-weight:600;color:var(--color-text-primary);border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.attachment-modal-close{background:none;border:none;font-size:20px;color:var(--color-text-secondary);cursor:pointer}.attachment-modal-close:hover{color:var(--color-error)}.attachment-modal-body{padding:16px 20px;overflow-y:auto;flex:1;background:var(--color-bg);border-radius:12px}.attachment-list{display:flex;flex-direction:column;gap:12px}.attachment-item{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;padding:12px 14px;display:flex;align-items:center;justify-content:space-between}.attachment-info{display:flex;align-items:center;gap:10px}.attachment-icon{font-size:20px;color:var(--color-primary)}.attachment-name{font-size:14px;font-weight:500;color:var(--color-text-primary);max-width:260px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attachment-type{font-size:12px;padding:2px 8px;border-radius:12px;background:var(--color-primary-hover);color:var(--color-primary);margin-left:8px}.attachment-actions{display:flex;gap:8px}.attachment-view{background:var(--color-primary-hover);color:var(--color-primary);padding:6px 10px;border-radius:6px;font-size:13px;font-weight:500;border:1px solid var(--color-border);transition:all .15s ease}.attachment-view:hover{background:var(--color-primary);color:var(--color-text-inverse)}.attachment-download{background:var(--color-success-bg);color:var(--color-success);padding:6px 10px;border-radius:6px;font-size:13px;font-weight:500;border:1px solid var(--color-border);transition:all .15s ease}.attachment-download:hover{background:var(--color-success);color:var(--color-text-inverse)}.no-attachments{text-align:center;color:var(--color-text-secondary);font-size:14px;padding:32px 0}.chat-modal-overlay{position:fixed;inset:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000}.chat-modal-content{background:#fff;width:700px;height:90vh;box-shadow:0 10px 30px #0003,0 1px 4px #0000001a;position:relative;border-radius:var(--radius-md)}.chat-modal-header{display:flex;align-items:center;justify-content:space-between;color:var(--color-text-inverse);background:#0c356a;padding:22px;height:10%;border-top-left-radius:var(--radius-md);border-top-right-radius:var(--radius-md)}.chat-modal-header-title{font-weight:500}.chat-modal-header-close{display:flex;align-items:center;justify-content:center;padding:5px;border-radius:var(--radius-sm);background-color:#fbfbfb33;border:none;color:var(--color-text-inverse);cursor:pointer;transition:transform .2s}.chat-modal-header-close:hover{transform:scale(1.07)}.chat-modal-main{display:flex;height:90%;width:100%;border-bottom-left-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md);overflow:hidden}.chat-modal-members{display:flex;flex-direction:column;height:100%;width:40%;background-color:var(--color-card);border-bottom-left-radius:var(--radius-md);border-right:1px solid var(--color-border)}.chat-modal-members-header{display:flex;align-items:center;gap:5px;padding:15px 20px;font-weight:600;font-size:var(--font-size-caption);color:var(--color-text-secondary);background:var(--color-bg);border-bottom:1px solid var(--color-border)}.chat-modal-members-list{display:flex;flex-direction:column;flex:1;padding:10px;overflow-y:auto;scrollbar-width:thin}.chat-member{background-color:var(--color-card);border:1px solid transparent;margin-top:5px;cursor:pointer;padding:10px 15px;position:relative;border-radius:var(--radius-md);transition:border .3s,background-color .1s}.chat-member.active{background-color:#eceff280;color:var(--color-primary);border:1px solid rgba(var(--color-primary-rgb));box-shadow:#1d3f954d 0 0 0 1px}.chat-member:hover{background-color:#eceff280;border:1px solid rgba(var(--color-primary-rgb))}.chat-member.active:before{content:"";position:absolute;left:-1px;top:7px;bottom:7px;width:4px;background:var(--color-text-primary);border-radius:2px}.chat-member-name{color:var(--color-text-primary);font-size:var(--font-size-primary-text);font-weight:600}.chat-member-role{color:var(--color-text-secondary);font-size:var(--font-size-secondary-text);font-weight:500;margin-top:5px}.chat-modal-messages{height:100%;width:100%;background-color:var(--color-bg);border-bottom-right-radius:var(--radius-md);display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;text-align:center}.messages-select-chat{height:40%;width:100%}.messages-select-chat .select-chat-title{margin-top:15px;font-size:var(--font-size-h3);font-weight:600}.messages-select-chat .select-chat-sub-title{margin-top:5px;font-size:var(--font-size-secondary-text)}.messages-empty-chat{height:calc(100% - 80px);width:100%;display:flex;flex-direction:column;justify-content:center;align-items:center}.messages-empty-chat .empty-chat-title{margin-top:15px;font-size:var(--font-size-h3);font-weight:600}.messages-empty-chat .empty-chat-sub-title{margin-top:5px;font-size:var(--font-size-secondary-text)}.message-box-container{width:100%;height:100%;display:flex;flex-direction:column;position:relative}.message-box-header{background-color:var(--color-card);border-bottom:1px solid var(--color-border);padding:15px 20px;display:flex;align-items:center;gap:10px}.message-box-header-title{font-size:var(--font-size-primary-text);color:var(--color-text-primary);font-weight:600}.message-box-header-msg-count{font-size:var(--font-size-secondary-text);color:var(--color-text-secondary);font-weight:500}.message-box-main{background-color:var(--color-bg);display:flex;flex-grow:1;flex-direction:column;gap:10px;overflow-y:auto;padding:15px 20px;scrollbar-width:thin;scrollbar-color:var(--color-border);margin-bottom:80px}.message-box-send-message{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;width:100%;height:80px;background-color:var(--color-card);padding:10px 0;border-top:1px solid var(--color-border)}.message-input-container{display:flex;align-items:center;justify-content:center;width:100%}.message-input-container input{background:var(--color-bg);padding:10px;margin-left:10px;width:100%;border-radius:var(--radius-sm);border:2px solid var(--color-border)}.message-send-btn-container{padding:10px}.message-send-btn{display:flex;align-items:center;justify-content:center;padding:7px 12px;background-color:#8496ae;color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:transform .2s}.message-send-btn:hover{transform:scale(1.02)}.message-text-container{border-radius:var(--radius-md);padding:15px;width:60%}.message-text-header{display:flex;align-items:center}.message-text-name{font-size:var(--font-size-text-primary);color:var(--color-text-primary);font-weight:600}.message-text-you-logo{padding:4px 8px;color:var(--color-text-inverse);background-color:var(--color-accent);border-radius:var(--radius-lg);font-size:var(--font-size-tiny);margin-left:6px}.message-text-time{margin-left:auto;font-size:var(--font-size-tiny);color:var(--color-text-secondary);font-weight:500}.message-text-body{display:flex}.message-text-body p{margin:10px 0 0;text-align:left}:root{--web-primary: #0A2E5D;--web-secondary: #64748b;--web-accent: #f97316;--web-bg: #f8fafc;--web-card-bg: #ffffff;--web-border: #e2e8f0;--web-success: #10b981;--web-warning: #f59e0b;--web-danger: #ef4444;--web-shadow-sm: 0 4px 15px rgba(10, 46, 93, .03);--web-shadow: 0 10px 25px -5px rgba(0, 0, 0, .05), 0 8px 10px -6px rgba(0, 0, 0, .05);--web-shadow-lg: 0 20px 25px -5px rgba(10, 46, 93, .1), 0 10px 10px -5px rgba(10, 46, 93, .04)}.web-page-container{min-height:100vh;padding:1.5rem 2rem;background:var(--web-bg);background-image:radial-gradient(circle at 100% 100%,rgba(10,46,93,.03) 0,transparent 25%),radial-gradient(circle at 0% 0%,rgba(224,89,30,.03) 0,transparent 25%);animation:webFadeIn .6s cubic-bezier(.16,1,.3,1)}.web-header{background:#fff;padding:1.5rem 2rem;border-radius:20px;margin-bottom:2rem;box-shadow:0 4px 20px #0a2e5d0d;border:1px solid rgba(10,46,93,.05)}.web-header-main{display:flex;flex-direction:column}.web-header-content{display:flex;justify-content:space-between;align-items:center;width:100%}.web-page-title{font-size:28px;font-weight:800;margin:0;letter-spacing:-.02em;color:var(--web-primary)}.web-breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--web-secondary);margin-top:4px;font-weight:500}.web-breadcrumb-item{transition:color .2s ease}.web-breadcrumb-item.active{color:var(--web-accent);font-weight:700}.web-breadcrumb-separator{color:#cbd5e1}.web-filters-row{display:flex;gap:1rem;margin-bottom:2rem;align-items:center;flex-wrap:wrap}.web-search-box{position:relative;flex:1;min-width:300px}.web-search-icon{position:absolute;left:1.25rem;top:50%;transform:translateY(-50%);color:#94a3b8}.web-search-input{width:100%;padding:.875rem 1.25rem .875rem 3rem;border:2px solid #f1f5f9;border-radius:1.75rem;font-size:.9375rem;font-weight:500;transition:all .3s cubic-bezier(.4,0,.2,1);background:#f8fafc;color:var(--web-primary)}.web-search-input:focus{outline:none;border-color:var(--web-primary);background:#fff;box-shadow:0 0 0 4px #0a2e5d14}.web-container{min-height:400px}.web-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.web-card{background:#fff;border-radius:1rem;padding:1.5rem;box-shadow:var(--web-shadow-sm);border:1px solid rgba(10,46,93,.05);transition:all .3s ease;cursor:pointer;position:relative;overflow:hidden;display:flex;flex-direction:column}.web-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--web-accent);opacity:0;transition:opacity .3s ease}.web-card:hover{transform:translateY(-4px);box-shadow:var(--web-shadow-lg);border-color:#0a2e5d1a}.web-card:hover:before{opacity:1}.web-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #f1f5f9}.web-card-header-left{display:flex;flex-direction:column;gap:.5rem}.web-status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:.5rem;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;width:fit-content}.web-status-badge.scheduled{background:#dbeafe;color:#1e40af}.web-status-badge.live{background:#dcfce7;color:#166534;animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.web-status-badge.completed{background:#f1f5f9;color:#475569}.web-status-badge.cancelled{background:#fee2e2;color:#991b1b}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.web-card-date{font-size:.875rem;color:#64748b;font-weight:600}.web-card-body{flex:1;display:flex;flex-direction:column}.web-title{font-size:1.25rem;font-weight:800;color:var(--web-primary);margin:0 0 .5rem;line-height:1.4}.web-description{font-size:.9375rem;color:var(--web-secondary);line-height:1.6;margin:0 0 1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.web-meta-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-top:auto;padding-top:1rem}.web-meta-item{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--web-secondary);font-weight:600;background:#f8fafc;padding:.5rem .75rem;border-radius:.5rem}.web-meta-item svg{color:var(--web-primary);flex-shrink:0}.web-card-footer{display:flex;gap:.75rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #f1f5f9}.web-btn-join{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:var(--web-primary);color:#fff;border:none;border-radius:.75rem;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #2563eb40}.web-btn-join:hover:not(:disabled){background:var(--web-primary);transform:translateY(-2px);box-shadow:0 8px 20px #0a2e5d4d}.web-btn-join:disabled{background:#cbd5e1;cursor:not-allowed;box-shadow:none;transform:none}.web-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:web-spin .8s linear infinite}@keyframes web-spin{to{transform:rotate(360deg)}}.web-btn-recordings{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:#fff;color:var(--web-primary);border:2px solid var(--web-primary);border-radius:.75rem;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .2s}.web-btn-recordings:hover{background:var(--web-primary);color:#fff}.web-loading,.web-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:5rem 2rem;text-align:center;background:#fff;border-radius:1.5rem;box-shadow:var(--web-shadow-sm)}.web-loading .spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:var(--web-primary);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1.5rem}.web-empty h3{font-size:1.5rem;font-weight:800;color:var(--web-primary);margin:0 0 .5rem}.web-empty p{color:#64748b;margin:0}@keyframes webFadeIn{0%{opacity:0}to{opacity:1}}@media(max-width:1200px){.web-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}}@media(max-width:768px){.web-page-container{padding:1rem}.web-header{padding:1.25rem 1.5rem}.web-header-content{flex-direction:column;align-items:flex-start;gap:1rem}.web-filters-row{flex-direction:column}.web-search-box{min-width:0;width:100%}.web-grid{grid-template-columns:1fr}.web-card{padding:1.25rem}}@media(max-width:480px){.web-page-title{font-size:22px}.web-meta-grid{grid-template-columns:1fr}.web-card-footer{flex-direction:column}}.web-modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:1rem}.web-modal-content{background:#fff;border-radius:1rem;max-width:700px;width:100%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.web-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid #f1f5f9}.web-modal-header h2{font-size:1.5rem;font-weight:700;color:var(--web-primary);margin:0}.web-modal-close{background:none;border:none;cursor:pointer;color:#64748b;padding:.5rem;border-radius:.5rem;transition:all .2s}.web-modal-close:hover{background:#f1f5f9;color:var(--web-primary)}.web-modal-body{padding:1.5rem;overflow-y:auto;flex:1}.web-modal-title{display:flex;align-items:center;gap:.75rem;padding:1rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:.75rem;margin-bottom:1.5rem;color:var(--web-primary);font-weight:600}.web-modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;gap:1rem}.web-modal-loading .spinner{width:40px;height:40px;border:3px solid #f1f5f9;border-top-color:var(--web-primary);border-radius:50%;animation:web-spin .8s linear infinite}.web-modal-loading p{color:#64748b;font-size:.875rem}.web-modal-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;gap:1rem}.web-modal-empty p{color:#64748b;font-size:.875rem}.web-recordings-list{display:flex;flex-direction:column;gap:.75rem}.web-recording-item{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:#fff;border:1px solid #e2e8f0;border-radius:.75rem;transition:all .2s}.web-recording-item:hover{border-color:var(--web-primary);box-shadow:0 4px 12px #0a2e5d1a}.web-recording-info{display:flex;align-items:center;gap:1rem;flex:1}.web-recording-icon{color:var(--web-primary);flex-shrink:0}.web-recording-details{flex:1}.web-recording-details h4{font-size:.9375rem;font-weight:600;color:#1e293b;margin:0 0 .25rem}.web-recording-meta{font-size:.8125rem;color:#64748b;margin:0}.web-recording-actions{display:flex;gap:.5rem}.web-recording-btn{display:flex;align-items:center;justify-content:center;padding:.5rem;background:var(--web-primary);color:#fff;border:none;border-radius:.5rem;cursor:pointer;transition:all .2s;text-decoration:none}.web-recording-btn:hover{background:#082340;transform:translateY(-1px)}.web-recording-player{display:flex;flex-direction:column;gap:1rem}.web-player-header{display:flex;align-items:center;gap:1rem;padding:1rem;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:.75rem}.web-player-back{background:#fff;border:1px solid #e2e8f0;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.875rem;font-weight:600;color:var(--web-primary);transition:all .2s}.web-player-back:hover{background:var(--web-primary);color:#fff;border-color:var(--web-primary)}.web-player-header h4{margin:0;font-size:1rem;color:#1e293b;flex:1}.web-player-container{position:relative;width:100%;padding-top:56.25%;background:#000;border-radius:.75rem;overflow:hidden}.web-recording-iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none;border-radius:.75rem}.web-recording-video{position:absolute;top:0;left:0;width:100%;height:100%;border:none;border-radius:.75rem;object-fit:contain;background:#000}.web-recording-video::-webkit-media-controls-panel{background:linear-gradient(transparent,#00000080)}.web-player-error{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:#1e293b}.web-player-error p{color:#cbd5e1;font-size:.875rem;margin:0}.profile-container{min-height:100vh;padding:2.5rem;background:#f8fafc;background-image:radial-gradient(circle at 100% 100%,rgba(10,46,93,.03) 0,transparent 25%),radial-gradient(circle at 0% 0%,rgba(224,89,30,.03) 0,transparent 25%);display:flex;flex-direction:column;gap:2rem}.profile-page-header{background:#fff;padding:1.5rem 2rem;border-radius:20px;box-shadow:0 4px 20px #0a2e5d0d;border:1px solid rgba(10,46,93,.05)}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%}.header-main-info{display:flex;flex-direction:column}.page-title{font-size:28px;font-weight:800;color:var(--color-primary);margin:0;letter-spacing:-.02em}.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#64748b;margin-top:4px;font-weight:500}.breadcrumb-item{transition:color .2s ease}.breadcrumb-separator{color:#cbd5e1}.breadcrumb-item.active{color:var(--color-accent);font-weight:700}.profile-hero-card{background:#fff;border-radius:24px;padding:2.5rem;box-shadow:0 4px 20px #0a2e5d0a;border:1px solid rgba(10,46,93,.05);display:flex;align-items:center;gap:3rem;position:relative;overflow:hidden}.profile-hero-card:after{content:"";position:absolute;top:0;right:0;width:300px;height:100%;background:linear-gradient(90deg,transparent,rgba(10,46,93,.02));pointer-events:none}.avatar-section{position:relative;display:flex;flex-direction:column;align-items:center;gap:1.25rem;z-index:1}.avatar-circle{width:160px;height:160px;border-radius:30px;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);display:flex;align-items:center;justify-content:center;font-size:4rem;font-weight:800;color:#fff;border:4px solid white;box-shadow:0 10px 25px #0a2e5d26;overflow:hidden;transition:all .3s ease}.avatar-image{width:100%;height:100%;object-fit:cover}.avatar-actions{display:flex;gap:.5rem;position:absolute;bottom:-15px;background:#fff;padding:6px;border-radius:12px;box-shadow:0 4px 15px #0000001a}.avatar-upload-btn,.avatar-remove-btn{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;transition:all .2s ease}.avatar-upload-btn{background:var(--color-primary);color:#fff}.avatar-remove-btn{background:#fee2e2;color:#ef4444}.avatar-upload-btn:hover{background:#1a4d8c;transform:scale(1.05)}.avatar-remove-btn:hover{background:#fecaca;transform:scale(1.05)}.profile-info-hero{flex:1}.profile-name{font-size:36px;font-weight:800;color:var(--color-primary);margin:0 0 .5rem;letter-spacing:-.02em}.profile-title-row{display:flex;align-items:center;gap:1.5rem;margin-bottom:1.25rem}.profile-role-badge{background:#0a2e5d0d;color:var(--color-primary);padding:6px 14px;border-radius:100px;font-size:14px;font-weight:700;display:flex;align-items:center;gap:8px}.profile-position-text{color:#64748b;font-weight:600;font-size:16px}.status-badge{display:inline-flex;align-items:center;gap:.6rem;padding:6px 14px;border-radius:100px;font-size:13px;font-weight:700}.status-badge.active{background:#dcfce7;color:#16a34a}.status-badge.inactive{background:#fee2e2;color:#dc2626}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.active{background:#16a34a;box-shadow:0 0 8px #16a34a}.status-dot.inactive{background:#dc2626;box-shadow:0 0 8px #dc2626}.action-section{display:flex;gap:1rem}.btn-primary,.button-primary{background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);color:#fff;border:none;padding:.8rem 1.8rem;border-radius:14px;font-weight:700;font-size:15px;display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #0a2e5d40}.btn-primary:hover,.button-primary:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0a2e5d4d}.btn-secondary{border:1px solid rgba(10,46,93,.1);padding:.8rem 1.8rem;border-radius:14px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:.75rem;transition:all .2s ease;background:#fff;color:var(--color-primary)}.btn-secondary:hover{background-color:#f1f5f9;transform:translateY(-2px);border-color:#0a2e5d33}.btn-secondary.cancel{border-color:#fee2e2;color:#ef4444}.btn-secondary.cancel:hover{background:#fff1f1}.btn-primary:disabled,.button-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed;transform:none}.profile-content-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}.profile-card{background:#fff;border-radius:24px;padding:2rem;box-shadow:0 4px 15px #0a2e5d08;border:1px solid rgba(10,46,93,.05);transition:all .3s ease}.profile-card:hover{transform:translateY(-5px);box-shadow:0 12px 30px #0a2e5d14}.card-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1.25rem;border-bottom:2.5px solid #f8fafc}.card-header svg{color:var(--color-primary);background:#0a2e5d0d;padding:10px;border-radius:14px}.section-title{font-size:1.25rem;font-weight:800;color:var(--color-primary);margin:0;letter-spacing:-.01em}.form-grid{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.6rem}.form-label{font-weight:700;color:#94a3b8;font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;display:flex;align-items:center;gap:.5rem}.form-input{padding:14px 18px;border:2px solid var(--color-primary);border-radius:16px;font-size:15px;background:#fff;color:var(--color-primary);transition:all .3s ease;font-weight:600;box-shadow:0 2px 8px #0a2e5d0a}.form-input:focus{outline:none;border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 4px #0a2e5d1f,0 4px 12px #0a2e5d14;transform:translateY(-1px)}.form-input:disabled{background:#f1f5f9;border-color:#e2e8f0;color:#64748b;cursor:not-allowed;font-weight:600;box-shadow:none}.form-value{padding:14px 18px;background:#f1f5f9;border:2px solid #e2e8f0;border-radius:16px;color:var(--color-primary);font-weight:700;font-size:15px;min-height:52px;display:flex;align-items:center}.email-display{color:var(--color-accent)}.loading{display:flex;flex-direction:column;justify-content:center;align-items:center;height:400px;gap:1rem;color:var(--color-primary);font-weight:700}.loading:after{content:"";width:40px;height:40px;border:4px solid rgba(10,46,93,.1);border-left-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.loading-spinner{width:100%;height:100%;border-radius:30px;background:#e0e0e0;position:relative;overflow:hidden}.loading-spinner:after{content:"";position:absolute;inset:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);animation:shimmer 1.4s infinite}@keyframes shimmer{to{transform:translate(100%)}}@media(max-width:1200px){.profile-container{padding:2rem}.profile-hero-card{padding:2rem;gap:2.5rem}}@media(max-width:1024px){.profile-content-grid{grid-template-columns:1fr;gap:1.5rem}.profile-name{font-size:32px}}@media(max-width:768px){.profile-container{padding:1.5rem;gap:1.5rem}.header-content{flex-direction:column;align-items:stretch;gap:1.25rem;text-align:left}.action-section{width:100%}.action-section button{flex:1;justify-content:center}.profile-hero-card{flex-direction:column;text-align:center;padding:2rem 1.5rem;gap:2rem}.profile-hero-card:after{display:none}.avatar-circle{width:140px;height:140px;font-size:3.5rem}.profile-title-row{justify-content:center;flex-wrap:wrap;gap:1rem}.profile-name{font-size:28px}.card-header{margin-bottom:1.5rem}.profile-card{padding:1.5rem}}@media(max-width:640px){.profile-container{padding:1rem}.profile-page-header{padding:1.25rem}.breadcrumb{display:none}.page-title{font-size:24px;text-align:center}.action-section{flex-direction:column}.profile-name{font-size:24px}.profile-title-row{flex-direction:column;gap:.75rem}.profile-role-badge{width:fit-content;margin:0 auto}}@media(max-width:480px){.profile-hero-card{padding:1.5rem 1rem}.avatar-circle{width:120px;height:120px;font-size:3rem;border-radius:24px}.form-value,.form-input{padding:12px 14px;font-size:14px}.section-title{font-size:1.1rem}.card-header svg{padding:8px;width:36px;height:36px}}.course-details-container{font-family:var(--font-family);background-color:var(--color-bg);min-height:100vh;padding:2rem;color:var(--color-text-primary);max-width:1400px;margin:0 auto;animation:fadeIn .3s cubic-bezier(.4,0,.2,1)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.cd-header-section{background:#fff;padding:2rem;border-radius:20px;margin-bottom:2rem;box-shadow:0 4px 20px #0a2e5d0d;border:1px solid rgba(10,46,93,.05)}.cd-breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:#64748b;font-weight:500;margin-bottom:1.5rem}.cd-breadcrumb-item{transition:color .2s ease;cursor:pointer;text-decoration:none;color:#64748b}.cd-breadcrumb-item:hover{color:var(--color-primary)}.cd-breadcrumb-item.active{color:var(--color-accent);font-weight:700}.cd-breadcrumb-separator{color:#cbd5e1}.cd-header-content{display:flex;flex-direction:column;gap:2rem}.cd-header-main{display:flex;flex-direction:column;gap:.75rem}.cd-page-title{font-size:2rem;font-weight:800;color:#0f172a;margin:0;letter-spacing:-.02em;line-height:1.2}.cd-description{font-size:1rem;color:#64748b;line-height:1.6;margin:0;max-width:900px}.cd-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem}.cd-info-card{background:#f8fafc;padding:1.5rem;border-radius:16px;display:flex;align-items:center;gap:1rem;border:1px solid #f1f5f9;transition:all .3s cubic-bezier(.4,0,.2,1);min-width:0}.cd-info-card:hover{background:#fff;box-shadow:0 4px 12px #0a2e5d14;transform:translateY(-2px)}.cd-info-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:12px;flex-shrink:0;color:#fff}.cd-icon-yellow{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.cd-icon-blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.cd-icon-purple{background:linear-gradient(135deg,#a78bfa,#8b5cf6)}.cd-icon-orange{background:linear-gradient(135deg,#fb923c,#f97316)}.cd-icon-red{background:linear-gradient(135deg,#f87171,#ef4444)}.cd-icon-green{background:linear-gradient(135deg,#34d399,#10b981)}.cd-info-content{display:flex;flex-direction:column;gap:.25rem;min-width:0}.cd-info-label{font-size:.6875rem;color:#94a3b8;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.cd-info-value{font-size:1.125rem;color:#0f172a;font-weight:700;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cd-tabs-section{background:#fff;border-radius:20px;padding:0 2rem;margin-bottom:2rem;box-shadow:0 4px 15px #0a2e5d08;border:1px solid rgba(10,46,93,.05)}.cd-tabs{display:flex;gap:2.5rem;overflow-x:auto;scrollbar-width:none}.cd-tabs::-webkit-scrollbar{display:none}.cd-tab-button{display:flex;align-items:center;gap:.625rem;padding:1.25rem 0;background:transparent;border:none;border-bottom:3px solid transparent;color:#64748b;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);white-space:nowrap;position:relative}.cd-tab-button:hover{color:var(--color-primary)}.cd-tab-button.active{color:var(--color-primary);border-bottom-color:var(--color-accent)}.cd-tab-button svg{flex-shrink:0}.cd-content-section{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 15px #0a2e5d08;border:1px solid rgba(10,46,93,.05);min-height:400px}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:1rem}@media(max-width:1200px){.cd-info-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}}@media(max-width:1024px){.cd-info-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}}@media(max-width:768px){.course-details-container{padding:1rem}.cd-header-section{padding:1.5rem}.cd-page-title{font-size:1.5rem}.cd-description{font-size:.9375rem}.cd-info-grid{grid-template-columns:1fr}.cd-tabs-section{padding:0 1rem}.cd-tabs{gap:1.5rem}.cd-tab-button{padding:1rem 0;font-size:.875rem}.cd-content-section{padding:1.5rem}}@media(max-width:640px){.cd-breadcrumb{font-size:.75rem}.cd-page-title{font-size:1.25rem}.cd-info-card{padding:1rem}.cd-tabs{gap:1.25rem}.cd-tab-button{padding:.875rem 0;gap:.5rem;font-size:.8125rem}.cd-tab-button svg{width:16px;height:16px}}.category-btn-container button.active{background-color:var(--color-text-primary);color:var(--color-card)}.category-btn-container button:hover{background-color:var(--color-accent);color:var(--color-card)}.main-content-container{display:flex;justify-content:center;align-items:center;background-color:var(--color-bg);padding:20px}.main-content{width:100%;border-radius:var(--radius-md);padding:30px 40px}.main-items-container{background-color:var(--color-bg);border:1px solid var(--color-border);padding:10px;border-radius:var(--radius-md)}.main-item .title-txt{font-weight:600}.homework-container{display:flex;flex-direction:column;gap:10px;margin-bottom:10px;cursor:pointer}.homework-container:hover{transform:scale(1.01);background-color:var(--color-card-hover);transition:background-color .3s,transform .3s}.homework-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;display:flex;justify-content:center;align-items:center;z-index:999;animation:fadeIn .3s}.homework-modal-content{background:var(--color-card);padding:20px 30px;border-radius:var(--radius-md);max-width:600px;width:90%;z-index:1000;animation:slideDown .3s}.homework-modal-content h2{margin-bottom:0}.homework-modal-description{padding-bottom:5px;color:var(--color-text-secondary)}input[type=file]{display:none}.custom-file-upload{padding:10px 20px;background:#000;color:#fff;cursor:pointer;border-radius:5px;display:inline-block;margin-right:10px}.homework-file-name{font-size:14px;color:#333}.homework-modal-dates{display:flex;justify-content:space-between;margin-top:20px;font-size:14px;color:var(--color-text-secondary);margin-bottom:15px}.homework-modal-dates .assigned-date{color:var(--color-text-primary);font-weight:600}.homework-modal-dates .due-date{color:var(--color-error);font-weight:600}.homework-modal-close-btn-container{display:flex;justify-content:flex-end}.homework-modal-close-btn{all:unset;cursor:pointer;padding:8px 12px;font-weight:600;background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm)}@keyframes slideDown{0%{transform:translateY(-20px);opacity:0}to{transform:translateY(0);opacity:1}}#submit-homework{display:none}.file-upload-sub-container{display:flex;align-items:center;justify-content:space-between}.btn-disable{opacity:.2}.submitted-urls{width:60%}.submitted-urls h4{margin-bottom:0}.submitted-urls ul{margin-top:5px;padding:0}.file-input-type-container{display:flex;justify-content:center;align-items:center;width:fit-content;padding:1px;border-radius:var(--radius-sm);background-color:var(--color-bg);border:1px solid var(--color-border)}.file-input-type{all:unset;cursor:pointer;font-size:var(--font-size-button);padding:10px;font-weight:500;border-radius:var(--radius-sm);transition:background-color .3s}.file-input-type.active{background-color:#000;color:#fff}.custom-choose-file-upload{background-color:var(--color-accent);color:var(--color-text-primary);font-weight:500;padding:5px 15px;color:#fff;cursor:pointer;border-radius:5px;display:inline-block;margin-right:10px}.homework-file-add-btn{cursor:pointer;font-size:var(--font-size-button);font-weight:600;padding:5px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm)}.file-link-container{display:flex;flex-direction:column;align-items:flex-end;width:60%;gap:2px}.url-input-container{display:flex;width:100%}.homework-modal-url-input{font-size:var(--font-size-tiny);border:1px solid var(--color-border);padding:10px;border-radius:var(--radius-sm);width:100%;color:var(--color-text-secondary)}.homework-file-remove-btn{cursor:pointer;font-size:var(--font-size-button);font-weight:600;background-color:var(--color-bg);padding:5px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-left:5px}.file-link-container .add-btn-container{display:flex;justify-content:flex-end;gap:5px;margin-top:5px}.grp-details-main-content{position:relative;padding:20px;background:#fff}.grp-timetable-header{margin-bottom:24px;display:flex;align-items:center;gap:8px}.grp-timetable-header .grp-title{font-size:24px;font-weight:600;color:var(--color-primary)}.grp-timetable-header .grp-name{font-size:16px;color:#666}.timetable-updating-overlay{position:absolute;inset:0;background:#fffc;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:100;animation:timetableFadeIn .2s ease}.timetable-updating-spinner{width:40px;height:40px;border:3px solid rgba(var(--color-primary-rgb),.1);border-top-color:var(--color-primary);border-radius:50%;animation:timetableSpin .8s linear infinite}.timetable-navigation{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:24px;padding:16px;background:linear-gradient(135deg,rgba(var(--color-primary-rgb),.03),rgba(var(--color-primary-rgb),.08));border-radius:12px;border:1px solid rgba(var(--color-primary-rgb),.1)}.timetable-nav-btn{width:40px;height:40px;border-radius:10px;border:1px solid rgba(var(--color-primary-rgb),.2);background:#fff;color:var(--color-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.timetable-nav-btn:hover:not(:disabled){background:var(--color-primary);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.timetable-nav-btn:disabled{opacity:.5;cursor:not-allowed}.timetable-week-info{display:flex;align-items:center;gap:10px;padding:10px 20px;background:#fff;border-radius:10px;border:1px solid rgba(var(--color-primary-rgb),.15);color:var(--color-primary);font-weight:600;font-size:15px}.timetable-week-info svg{flex-shrink:0}.timetable-wrapper{overflow-x:auto;border-radius:12px;border:1px solid rgba(var(--color-primary-rgb),.1);background:#fff;box-shadow:0 2px 8px #0000000d}.timetable-table{width:100%;border-collapse:collapse;min-width:900px}.timetable-table thead{background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);position:sticky;top:0;z-index:10}.timetable-time-header,.timetable-day-header{padding:16px;text-align:center;color:#fff;font-weight:600;font-size:14px;border-right:1px solid rgba(255,255,255,.1)}.timetable-time-header{width:140px;display:flex;align-items:center;justify-content:center;gap:8px;position:sticky;left:0;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);z-index:11}.timetable-day-header{min-width:180px}.timetable-day-header .day-name{display:block;font-size:15px;margin-bottom:4px}.timetable-day-header .day-short{display:block;font-size:12px;opacity:.8}.timetable-table tbody tr{border-bottom:1px solid rgba(var(--color-primary-rgb),.08)}.timetable-table tbody tr:hover{background:rgba(var(--color-primary-rgb),.02)}.timetable-time-cell{padding:12px;text-align:center;font-weight:600;font-size:13px;color:var(--color-primary);background:linear-gradient(135deg,rgba(var(--color-primary-rgb),.03),rgba(var(--color-primary-rgb),.08));border-right:1px solid rgba(var(--color-primary-rgb),.1);position:sticky;left:0;z-index:5;display:flex;align-items:center;justify-content:center;gap:6px;min-height:120px}.timetable-empty-cell{padding:12px;text-align:center;border-right:1px solid rgba(var(--color-primary-rgb),.08);min-height:120px}.timetable-break-cell{padding:12px;text-align:center;border-right:1px solid rgba(var(--color-primary-rgb),.08);background:linear-gradient(135deg,#ff980014,#ff980026)}.break-content{display:flex;align-items:center;justify-content:center;gap:8px;font-weight:600;color:#f57c00;font-size:14px}.timetable-session-cell{padding:12px;border-right:1px solid rgba(var(--color-primary-rgb),.08);vertical-align:top}.timetable-session-card{background:linear-gradient(135deg,rgba(var(--color-primary-rgb),.04),rgba(var(--color-primary-rgb),.08));border:1px solid rgba(var(--color-primary-rgb),.15);border-radius:10px;padding:12px;min-height:100px;display:flex;flex-direction:column;gap:10px;transition:all .3s cubic-bezier(.4,0,.2,1)}.timetable-session-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.15);border-color:rgba(var(--color-primary-rgb),.3)}.session-header{display:flex;align-items:center;gap:8px;padding-bottom:8px;border-bottom:1px solid rgba(var(--color-primary-rgb),.1)}.session-header svg{color:var(--color-primary);flex-shrink:0}.session-subject{font-weight:600;font-size:14px;color:var(--color-primary);flex:1}.session-teacher{display:flex;align-items:center;gap:6px;font-size:13px;color:#555}.session-teacher svg{color:#666;flex-shrink:0}.session-module{background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);padding:6px 10px;border-radius:6px;font-size:12px;font-weight:500;text-align:center;border:1px solid rgba(var(--color-primary-rgb),.2)}@keyframes timetableFadeIn{0%{opacity:0}to{opacity:1}}@keyframes timetableSpin{to{transform:rotate(360deg)}}@media(max-width:1024px){.timetable-day-header{min-width:150px}.timetable-time-cell,.timetable-time-header{width:120px}}@media(max-width:768px){.timetable-navigation{flex-wrap:wrap;gap:12px}.timetable-week-info{width:100%;justify-content:center}.grp-timetable-header{flex-direction:column;align-items:flex-start;gap:4px}}.teacher-tab-container{padding:0}.teacher-tab-header{margin-bottom:2rem}.teacher-tab-title-section{display:flex;align-items:center;gap:1rem}.teacher-tab-title{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0}.teacher-tab-count{font-size:.875rem;color:#64748b;font-weight:600;background:#f1f5f9;padding:.375rem .875rem;border-radius:20px}.teacher-table-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.teacher-table{width:100%;border-collapse:collapse;font-size:.9375rem}.teacher-table thead{background:#f8fafc;border-bottom:1px solid #e2e8f0}.teacher-table th{padding:1rem 1.5rem;text-align:left;font-size:.8125rem;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.5px}.teacher-table-action-header{text-align:center;width:100px}.teacher-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .2s ease}.teacher-table tbody tr:last-child{border-bottom:none}.teacher-table tbody tr:hover{background:#f8fafc}.teacher-table td{padding:1.25rem 1.5rem;color:#334155;vertical-align:middle}.teacher-name-cell{display:flex;align-items:center;gap:.875rem}.teacher-avatar-small{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.teacher-name-text{font-weight:600;color:#0f172a;font-size:.9375rem}.teacher-email-cell{display:flex;align-items:center;gap:.5rem;color:#64748b}.teacher-email-cell svg{color:#94a3b8;flex-shrink:0}.teacher-subjects-cell{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.subject-badge{display:inline-block;padding:.375rem .75rem;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);border-radius:6px;font-size:.8125rem;font-weight:600;white-space:nowrap}.no-subjects-text{color:#94a3b8;font-size:.875rem}.teacher-chat-btn{width:40px;height:40px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;margin:0 auto}.teacher-chat-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:scale(1.05)}@media(max-width:1024px){.teacher-table{font-size:.875rem}.teacher-table th,.teacher-table td{padding:1rem}}@media(max-width:768px){.teacher-tab-title-section{flex-direction:column;align-items:flex-start;gap:.5rem}.teacher-tab-title{font-size:1.25rem}.teacher-table-wrapper{overflow-x:auto}.teacher-table{min-width:600px}.teacher-table th,.teacher-table td{padding:.75rem}.teacher-name-cell{gap:.625rem}.teacher-avatar-small{width:36px;height:36px}}.chat-sidebar-overlay{position:fixed;inset:0;background:#0a2e5d33;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:999;animation:fadeIn .4s cubic-bezier(.165,.84,.44,1)}.chat-sidebar{position:fixed;top:0;right:-450px;width:450px;height:100vh;background:#fff;box-shadow:-10px 0 50px #00000026;z-index:1000;display:flex;flex-direction:column;transition:right .5s cubic-bezier(.165,.84,.44,1);border-left:1px solid rgba(10,46,93,.1)}.chat-sidebar.open{right:0}.chat-sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;background:var(--color-primary);background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);color:#fff;box-shadow:0 4px 12px #0a2e5d33;position:relative;z-index:10}.chat-recipient-info{display:flex;align-items:center;gap:1.1rem}.chat-recipient-avatar{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#fff,#e2e8f0);display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:var(--color-primary);border:3px solid rgba(255,255,255,.25);box-shadow:0 4px 10px #0000001a;overflow:hidden;transition:transform .3s ease}.chat-recipient-avatar:hover{transform:scale(1.05)}.chat-recipient-avatar img{width:100%;height:100%;object-fit:cover}.chat-recipient-details h3{margin:0;font-size:1.25rem;font-weight:700;letter-spacing:-.01em;color:#fff}.chat-recipient-meta{display:flex;align-items:center;gap:.6rem;margin-top:.3rem}.chat-user-type{font-size:.75rem;padding:.2rem .6rem;background:#ffffff26;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.2);border-radius:2rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.chat-status{font-size:.8rem;display:flex;align-items:center;gap:.4rem;font-weight:500;opacity:.95}.chat-status.online:before{content:"";width:10px;height:10px;border-radius:50%;background:#10b981;box-shadow:0 0 10px #10b981cc;border:2px solid rgba(255,255,255,.2)}.chat-close-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.2);color:#fff;width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.chat-close-btn:hover{background:#ffffff4d;transform:rotate(90deg);box-shadow:0 0 15px #fff3}.chat-messages-container{flex:1;overflow-y:auto;padding:1.5rem;background:#f1f5f9;background-image:radial-gradient(circle at 100% 100%,#e2e8f0 0,transparent 20%),radial-gradient(circle at 0% 0%,#e2e8f0 0,transparent 20%);display:flex;flex-direction:column;gap:1.25rem;position:relative}.chat-messages-container::-webkit-scrollbar{width:5px}.chat-messages-container::-webkit-scrollbar-track{background:transparent}.chat-messages-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.chat-messages-container::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}.chat-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#94a3b8;text-align:center;padding:2rem}.chat-empty-state svg{color:var(--color-primary);opacity:.2;margin-bottom:1.5rem;animation:pulse 2s infinite ease-in-out}@keyframes pulse{0%{transform:scale(1);opacity:.1}50%{transform:scale(1.1);opacity:.2}to{transform:scale(1);opacity:.1}}.chat-empty-state p{font-size:1.25rem;font-weight:700;color:var(--color-primary);margin:.5rem 0;opacity:.8}.chat-empty-state span{font-size:.95rem;color:#64748b;max-width:250px;line-height:1.4}.chat-message{display:flex;margin-bottom:.5rem;background:transparent!important;border:none!important;width:100%}.chat-message.sent{justify-content:flex-end}.chat-message.received{justify-content:flex-start}.chat-message-bubble{max-width:80%;padding:1rem 1.25rem;border-radius:1.25rem;position:relative;box-shadow:0 4px 12px #0000000d;animation:messageSlideIn .4s cubic-bezier(.165,.84,.44,1)}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(15px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.chat-message.sent .chat-message-bubble{background:var(--color-primary);background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);color:#fff;border-bottom-right-radius:.35rem;box-shadow:0 6px 15px #0a2e5d40}.chat-message.received .chat-message-bubble{background:#fff;color:#1e293b;border-bottom-left-radius:.35rem;border:1px solid rgba(10,46,93,.05)}.chat-message-bubble p{margin:0;font-size:.95rem;line-height:1.6;word-wrap:break-word;color:inherit}.chat-message-time{display:block;font-size:.72rem;margin-top:.5rem;font-weight:600;letter-spacing:.02em}.chat-message.sent .chat-message-time{text-align:right;color:#ffffffb3}.chat-message.received .chat-message-time{text-align:left;color:#94a3b8}.chat-input-container{display:flex;align-items:center;gap:1rem;padding:1.5rem;background:#fff;border-top:1px solid rgba(10,46,93,.1);box-shadow:0 -4px 15px #00000008;z-index:10}.chat-input{flex:1;padding:1rem 1.5rem;border:2px solid #e2e8f0;border-radius:3rem;font-size:1rem;outline:none;transition:all .3s ease;background:#f8fafc;color:var(--color-text-primary)}.chat-input:focus{border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 4px #0a2e5d14}.chat-input::placeholder{color:#94a3b8;font-weight:500}.chat-send-btn{width:48px;height:48px;border-radius:50%;border:none;background:var(--color-primary);background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 4px 12px #0a2e5d59}.chat-send-btn:hover:not(:disabled){transform:scale(1.1) rotate(5deg);box-shadow:0 8px 20px #0a2e5d73}.chat-send-btn:active:not(:disabled){transform:scale(.9) rotate(0)}.chat-send-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;background:#94a3b8}@media(max-width:768px){.chat-sidebar{width:100%;right:-100%}}@media(max-width:480px){.chat-sidebar-header,.chat-messages-container{padding:1.25rem}.chat-input-container{padding:1.25rem;gap:.75rem}.chat-message-bubble{max-width:88%;padding:.85rem 1.1rem}.chat-input{padding:.85rem 1.25rem}.chat-send-btn{width:44px;height:44px}}.subject-tab-container{padding:0}.subject-tab-header{margin-bottom:2rem}.subject-tab-title-section{display:flex;align-items:center;gap:1rem}.subject-tab-title{font-size:1.5rem;font-weight:700;color:#0f172a;margin:0}.subject-tab-count{font-size:.875rem;color:#64748b;font-weight:600;background:#f1f5f9;padding:.375rem .875rem;border-radius:20px}.subject-content-wrapper{display:flex;gap:1.5rem;transition:all .3s cubic-bezier(.4,0,.2,1)}.subject-table-section{flex:1;transition:all .3s cubic-bezier(.4,0,.2,1)}.subject-content-wrapper.split-view .subject-table-section{flex:0 0 30%;min-width:30%}.subject-recording-section{flex:1;animation:slideIn .3s cubic-bezier(.4,0,.2,1)}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.subject-table-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.subject-table{width:100%;border-collapse:collapse;font-size:.9375rem}.subject-table thead{background:#f8fafc;border-bottom:1px solid #e2e8f0}.subject-table th{padding:1rem 1.5rem;text-align:left;font-size:.8125rem;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.5px}.subject-table-action-header{text-align:center;width:120px}.subject-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .2s ease;cursor:pointer}.subject-table tbody tr:last-child{border-bottom:none}.subject-table tbody tr:hover{background:#f8fafc}.subject-table tbody tr.selected-row{background:rgba(var(--color-primary-rgb),.05);border-left:3px solid var(--color-primary)}.subject-table td{padding:1.25rem 1.5rem;color:#334155;vertical-align:middle}.subject-name-cell{display:flex;align-items:center;gap:.875rem}.subject-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.subject-info{display:flex;flex-direction:column;gap:.25rem}.subject-name-text{font-weight:600;color:#0f172a;font-size:.9375rem}.subject-id-text{font-size:.75rem;color:#94a3b8;font-weight:500}.subject-teachers-cell{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.teacher-badge{display:inline-block;padding:.375rem .75rem;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);border-radius:6px;font-size:.8125rem;font-weight:600;white-space:nowrap}.no-teachers-text{color:#94a3b8;font-size:.875rem}.subject-description-cell{color:#64748b;font-size:.875rem;line-height:1.5;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.subject-actions-cell{display:flex;gap:.5rem;justify-content:center;align-items:center}.subject-recording-btn,.subject-meeting-btn{width:40px;height:40px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;text-decoration:none}.subject-recording-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:scale(1.05)}.subject-meeting-btn:hover{background:#3b82f6;color:#fff;border-color:#3b82f6;transform:scale(1.05)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;gap:1rem}.loading-spinner{width:48px;height:48px;border:4px solid #f1f5f9;border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@media(max-width:1024px){.subject-content-wrapper.split-view{flex-direction:column}.subject-content-wrapper.split-view .subject-table-section{flex:1;min-width:100%}.subject-table{font-size:.875rem}.subject-table th,.subject-table td{padding:1rem}.subject-description-cell{max-width:200px}}@media(max-width:768px){.subject-tab-title-section{flex-direction:column;align-items:flex-start;gap:.5rem}.subject-tab-title{font-size:1.25rem}.subject-table-wrapper{overflow-x:auto}.subject-table{min-width:700px}.subject-table th,.subject-table td{padding:.75rem}.subject-name-cell{gap:.625rem}.subject-icon{width:36px;height:36px}}.recording-panel{background:#fff;border:1px solid #e2e8f0;border-radius:12px;height:fit-content;max-height:calc(100vh - 300px);display:flex;flex-direction:column;overflow:hidden}.recording-panel-header{padding:1.5rem;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:flex-start;background:#f8fafc}.recording-header-content{display:flex;gap:1rem;align-items:flex-start}.recording-subject-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.recording-subject-info{display:flex;flex-direction:column;gap:.375rem}.recording-subject-name{font-size:1.125rem;font-weight:700;color:#0f172a;margin:0;line-height:1.3}.recording-subject-meta{display:flex;align-items:center;gap:.75rem;font-size:.8125rem;color:#64748b}.recording-subject-id{background:#8b5cf61a;color:#7c3aed;padding:.25rem .625rem;border-radius:6px;font-weight:600}.recording-count{font-weight:500}.recording-close-btn{width:36px;height:36px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0}.recording-close-btn:hover{background:#fee2e2;color:#ef4444;border-color:#fecaca}.recording-list-container{padding:1rem;overflow-y:auto;flex:1}.recording-list-container::-webkit-scrollbar{width:6px}.recording-list-container::-webkit-scrollbar-track{background:#f1f5f9;border-radius:3px}.recording-list-container::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}.recording-list-container::-webkit-scrollbar-thumb:hover{background:#94a3b8}.recording-item{display:flex;gap:1rem;padding:1rem;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:.75rem;cursor:pointer;transition:all .2s ease}.recording-item:last-child{margin-bottom:0}.recording-item:hover{background:#f8fafc;border-color:#a78bfa;box-shadow:0 2px 8px #8b5cf61a}.recording-play-icon{width:44px;height:44px;border-radius:10px;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0;transition:transform .2s ease}.recording-item:hover .recording-play-icon{transform:scale(1.1)}.recording-details{flex:1;min-width:0}.recording-title{font-size:.9375rem;font-weight:600;color:#0f172a;margin:0 0 .5rem;line-height:1.4}.recording-metadata{display:flex;flex-wrap:wrap;gap:1rem}.recording-meta-item{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:#64748b;font-weight:500}.recording-meta-item svg{color:#94a3b8;flex-shrink:0}.no-recordings{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1rem;text-align:center;color:#94a3b8}.no-recordings svg{margin-bottom:1rem;opacity:.5}.no-recordings p{margin:0;font-size:.9375rem;font-weight:500}@media(max-width:768px){.recording-panel-header{padding:1rem}.recording-subject-icon{width:40px;height:40px}.recording-subject-name{font-size:1rem}.recording-list-container{padding:.75rem}.recording-item{padding:.875rem}.recording-play-icon{width:38px;height:38px}.recording-title{font-size:.875rem}.recording-metadata{gap:.75rem}.recording-meta-item{font-size:.75rem}}.homework-tab-container{width:100%;display:flex;flex-direction:column;gap:1.5rem}.homework-tab-header{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}.homework-tab-title-section{display:flex;align-items:center;gap:.75rem}.homework-tab-title{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.homework-tab-count{display:inline-flex;align-items:center;padding:.375rem .75rem;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);border-radius:20px;font-size:.875rem;font-weight:600}.homework-split-view{display:flex;gap:1.5rem;min-height:600px}.homework-split-view .homework-table-wrapper{flex:1;overflow-y:auto;border-radius:12px;border:1px solid #e2e8f0;background:#fff;transition:flex .3s ease}.homework-split-view.split-active .homework-table-wrapper{flex:0 0 30%}.homework-details-panel{flex:0 0 70%;overflow-y:auto;border-radius:12px;border:1px solid #e2e8f0;background:#fff;display:flex;flex-direction:column}.homework-details-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e2e8f0;position:sticky;top:0;background:#fff;z-index:10}.homework-details-header h3{margin:0;font-size:1.25rem;font-weight:700;color:#1e293b}.homework-details-close{width:36px;height:36px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.homework-details-close:hover{background:#f8fafc;border-color:#cbd5e1;color:#1e293b}.homework-search-section{display:flex;gap:.75rem;align-items:center;flex:1;max-width:600px}.homework-search-box{position:relative;flex:1;min-width:200px}.homework-search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.homework-search-box input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid #e2e8f0;border-radius:10px;font-size:.875rem;color:#1e293b;background:#fff;transition:all .2s cubic-bezier(.4,0,.2,1)}.homework-search-box input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.homework-search-box input::placeholder{color:#94a3b8}.homework-category-filter{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:10px;font-size:.875rem;font-weight:500;color:#475569;background:#fff;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);min-width:150px}.homework-category-filter:hover{border-color:var(--color-primary)}.homework-category-filter:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.homework-table-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.homework-table{width:100%;border-collapse:collapse}.homework-table thead{background:#f8fafc;border-bottom:1px solid #e2e8f0}.homework-table thead th{padding:1rem 1.25rem;text-align:left;font-size:.75rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.homework-table-action-header{text-align:center!important}.homework-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .2s cubic-bezier(.4,0,.2,1);cursor:pointer}.homework-table tbody tr:last-child{border-bottom:none}.homework-table tbody tr:hover{background:#f8fafc}.homework-table tbody tr.selected-row{background:#e0f2fe;border-left:3px solid var(--color-primary)}.homework-table tbody tr.selected-row:hover{background:#bae6fd}.homework-table tbody td{padding:1.25rem;font-size:.875rem;color:#475569;vertical-align:middle}.homework-title-cell{display:flex;align-items:center;gap:.75rem}.homework-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.homework-title-text{font-weight:600;color:#1e293b;line-height:1.4}.homework-subject-cell{display:flex;align-items:center;gap:.5rem}.subject-icon-small{color:#64748b;flex-shrink:0}.homework-date-cell{display:flex;align-items:center;gap:.5rem}.calendar-icon-small{color:#64748b;flex-shrink:0}.homework-type-badge{display:inline-flex;padding:.375rem .75rem;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);border-radius:6px;font-size:.8125rem;font-weight:600;white-space:nowrap}.homework-status-badge{display:inline-flex;padding:.375rem .75rem;border-radius:6px;font-size:.8125rem;font-weight:600;white-space:nowrap}.homework-status-badge.pending{background:#fef3c7;color:#d97706}.homework-status-badge.submitted{background:#dbeafe;color:#2563eb}.homework-status-badge.graded{background:#dcfce7;color:#16a34a}.homework-status-badge.late{background:#fee2e2;color:#dc2626}.homework-actions-cell{display:flex;gap:.5rem;justify-content:center;align-items:center}.homework-submit-btn,.homework-chat-btn{width:40px;height:40px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.homework-submit-btn:hover,.homework-chat-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:scale(1.05)}.homework-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s cubic-bezier(.4,0,.2,1)}.homework-modal-content{background:#fff;border-radius:16px;width:90%;max-width:600px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:modalSlideIn .3s cubic-bezier(.4,0,.2,1)}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.homework-modal-header{padding:1.5rem;border-bottom:1px solid #e2e8f0;display:flex;flex-direction:column;gap:1rem}.homework-modal-header-top{display:flex;align-items:flex-start;gap:1rem}.homework-modal-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.homework-modal-title-section{flex:1;min-width:0}.homework-modal-title{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0 0 .25rem}.homework-modal-subtitle{font-size:.875rem;color:#64748b;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.homework-modal-close-btn{width:36px;height:36px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0}.homework-modal-close-btn:hover{background:#fee2e2;color:#dc2626;border-color:#fecaca}.homework-modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.homework-file-type-tabs{display:flex;gap:.5rem;padding:.5rem;background:#f8fafc;border-radius:10px}.homework-file-type-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:1px solid transparent;border-radius:8px;background:transparent;color:#64748b;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.homework-file-type-tab:hover{background:#fff;color:#475569}.homework-file-type-tab.active{background:#fff;color:var(--color-primary);border-color:var(--color-primary);box-shadow:0 1px 3px #0000001a}.homework-file-type-tab:disabled{opacity:.5;cursor:not-allowed}.homework-modal-body{padding:1.5rem;overflow-y:auto;flex:1}.homework-attachments-list{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.homework-attachment-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;transition:all .2s cubic-bezier(.4,0,.2,1)}.homework-attachment-item:hover{background:#f1f5f9;border-color:#cbd5e1}.attachment-info{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.attachment-icon{color:#64748b;flex-shrink:0}.attachment-url{font-size:.875rem;color:#475569;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-action-btn{width:36px;height:36px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.attachment-action-btn.view-btn{color:#3b82f6}.attachment-action-btn.view-btn:hover{background:#dbeafe;border-color:#3b82f6;transform:translateY(-2px)}.attachment-action-btn.download-btn{color:var(--color-primary)}.attachment-action-btn.download-btn:hover{background:rgba(var(--color-primary-rgb),.1);border-color:var(--color-primary);transform:translateY(-2px)}.attachment-action-btn.remove-btn{color:#ef4444}.attachment-action-btn.remove-btn:hover{background:#fee2e2;border-color:#ef4444;transform:translateY(-2px)}.attachment-action-btn:disabled{opacity:.5;cursor:not-allowed}.homework-upload-section{display:flex;flex-direction:column;gap:1rem}.attachment-list{display:flex;flex-direction:column;gap:.75rem}.attachment-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;transition:all .2s cubic-bezier(.4,0,.2,1)}.attachment-item:hover{border-color:#cbd5e1;box-shadow:0 2px 8px #0000000d;transform:translateY(-1px)}.attachment-info{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.attachment-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;color:#fff;flex-shrink:0}.attachment-details{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.attachment-name{font-size:.9375rem;font-weight:600;color:#1e293b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-type{font-size:.75rem;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.5px}.attachment-actions{display:flex;gap:.5rem;flex-shrink:0}.attachment-view-btn,.attachment-download-btn,.attachment-remove-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);border:1px solid}.attachment-view-btn{background:#fff;color:#3b82f6;border-color:#3b82f6}.attachment-view-btn:hover:not(:disabled){background:#3b82f6;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.attachment-download-btn{background:#fff;color:var(--color-primary);border-color:var(--color-primary)}.attachment-download-btn:hover:not(:disabled){background:var(--color-primary);color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.3)}.attachment-remove-btn{background:#fff;color:#ef4444;border-color:#ef4444}.attachment-remove-btn:hover:not(:disabled){background:#ef4444;color:#fff;transform:translateY(-1px);box-shadow:0 4px 12px #ef44444d}.attachment-view-btn:disabled,.attachment-download-btn:disabled,.attachment-remove-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.homework-local-upload{display:flex;flex-direction:column;gap:1rem}.homework-file-label{display:inline-flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem 1.5rem;background:#fff;border:2px dashed #cbd5e1;border-radius:12px;color:#64748b;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);align-self:flex-start}.homework-file-label:hover{background:#f8fafc;border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.15)}.homework-local-upload input[type=file]{display:none}.homework-link-upload{display:flex;flex-direction:column;gap:.75rem}.homework-url-input-row{display:flex;gap:.5rem;align-items:center}.homework-url-input{flex:1;padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:10px;font-size:.875rem;color:#1e293b;background:#fff;transition:all .2s cubic-bezier(.4,0,.2,1)}.homework-url-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.homework-url-input::placeholder{color:#94a3b8}.homework-url-input:disabled{opacity:.5;cursor:not-allowed;background:#f8fafc}.homework-url-remove-btn{width:36px;height:36px;border-radius:8px;border:1px solid #e2e8f0;background:#fff;color:#dc2626;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0}.homework-url-remove-btn:hover{background:#fee2e2;border-color:#fecaca}.homework-url-remove-btn:disabled{opacity:.5;cursor:not-allowed}.homework-link-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:.5rem}.homework-upload-btn{width:100%;padding:.875rem 1.5rem;background:var(--color-primary);color:#fff;border:none;border-radius:12px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px rgba(var(--color-primary-rgb),.25)}.homework-upload-btn:hover:not(:disabled){background:#1a4d8c;transform:translateY(-2px);box-shadow:0 6px 16px rgba(var(--color-primary-rgb),.35)}.homework-upload-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.homework-add-url-btn{padding:.75rem 1.5rem;background:#fff;color:var(--color-primary);border:1px solid var(--color-primary);border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.homework-add-url-btn:hover{background:var(--color-primary);color:#fff;transform:translateY(-1px)}.homework-add-url-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.homework-remove-submission-btn{width:100%;padding:.75rem 1.5rem;background:#fff;color:#dc2626;border:1px solid #dc2626;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.homework-remove-submission-btn:hover{background:#dc2626;color:#fff;transform:translateY(-1px)}.homework-remove-submission-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.homework-overdue-text{display:block;padding:.75rem 1rem;background:#fee2e2;color:#dc2626;border:1px solid #fecaca;border-radius:10px;text-align:center;font-size:.875rem;font-weight:600}@media(max-width:1024px){.homework-tab-header{flex-direction:column;align-items:stretch}.homework-search-section{max-width:none}}@media(max-width:768px){.homework-tab-title{font-size:1.25rem}.homework-table thead th{padding:.75rem 1rem;font-size:.6875rem}.homework-table tbody td{padding:1rem}.homework-actions-cell{flex-wrap:wrap}.homework-modal-content{max-width:95%}.homework-modal-header,.homework-modal-body{padding:1.25rem}.homework-attachment-item{flex-direction:column;align-items:flex-start}.attachment-actions{width:100%;justify-content:flex-end}}@media(max-width:640px){.homework-tab-title-section{flex-direction:column;align-items:flex-start}.homework-search-section{flex-direction:column}.homework-category-filter{width:100%}.homework-table{font-size:.8125rem}.homework-title-cell{flex-direction:column;align-items:flex-start}.homework-modal-header-top{flex-direction:column}.homework-modal-close-btn{align-self:flex-end}.homework-local-upload{flex-direction:column}.homework-file-label{width:100%}.homework-link-actions{flex-direction:column}.homework-upload-btn,.homework-add-url-btn{width:100%}}.homework-section-title{font-size:1rem;font-weight:700;color:var(--color-primary);margin:0 0 1rem;padding-bottom:.5rem;border-bottom:2px solid rgba(var(--color-primary-rgb),.1)}.grp-homework-modal-overlay{position:fixed;inset:0;background:#0a2e5d73;display:flex;align-items:center;justify-content:center;z-index:1000}.grp-homework-modal-content{background:var(--color-card);width:520px;max-width:90%;max-height:80vh;border-radius:12px;box-shadow:0 20px 40px #00000026;display:flex;flex-direction:column;animation:modalFadeIn .2s ease-out}.comment-modal-header{padding:0 20px 16px;font-size:18px;font-weight:600;color:var(--color-text-primary);border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;align-items:center}.comment-modal-body{padding:16px 20px;overflow-y:auto;flex:1;background:var(--color-bg)}.comment-item{background:var(--color-card);border:1px solid var(--color-border);border-radius:8px;padding:12px 14px;margin-bottom:12px}.comment-item p{margin:0 0 6px;font-size:14px;color:var(--color-text-primary);line-height:1.5}.comment-item small{font-size:12px;color:var(--color-text-secondary)}.no-comments{text-align:center;color:var(--color-text-secondary);font-size:14px;padding:32px 0}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.task-modal-overlay{position:fixed;inset:0;background:#0f172abf;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:20px;z-index:2000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.task-modal-content{background:#fff;width:100%;max-width:900px;height:auto;max-height:85vh;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.task-modal-header{padding:20px 32px;background:#fff;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}.task-modal-header h2{margin:0;font-size:18px;font-weight:700;color:#0f172a;display:flex;align-items:center;gap:10px}.task-modal-close{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:none;background:#f8fafc;color:#64748b;cursor:pointer;transition:all .2s}.task-modal-close:hover{background:#fee2e2;color:#ef4444;transform:rotate(90deg)}.task-modal-body{flex:1;overflow-y:auto;padding:32px;background:#f8fafc}.task-modern-header{margin-bottom:24px}.task-badges{display:flex;gap:8px;margin-bottom:12px;flex-wrap:nowrap;align-items:center}.task-pill{padding:4px 12px;border-radius:16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.task-pill.status-completed{background:#dcfce7;color:#166534}.task-pill.status-pending{background:#fef3c7;color:#92400e}.task-pill.status-overdue{background:#fee2e2;color:#991b1b}.task-pill.status-in-progress,.task-pill.status-in_progress{background:#dbeafe;color:#1e40af}.task-pill.status-active{background:#d1fae5;color:#065f46}.task-pill.type-pill{background:#f1f5f9;color:#475569}.task-title-modern{margin:0;font-size:24px;font-weight:800;color:var(--color-primary, #1e40af);line-height:1.3}.task-modern-grid{display:grid;gap:16px;grid-template-columns:1fr}.task-info-card{background:#fff;border-radius:12px;padding:20px;border:1px solid #e2e8f0;display:flex;flex-direction:column;gap:16px}.info-card-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.info-item{display:flex;gap:12px;align-items:flex-start}.info-icon{color:var(--color-primary, #1e40af);flex-shrink:0;margin-top:2px}.info-label{font-size:11px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.info-value{font-size:14px;font-weight:600;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-description-card{background:#fff;border-radius:12px;padding:20px;border:1px solid #e2e8f0}.card-header-modern{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;color:var(--color-primary, #1e40af);letter-spacing:.5px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #f1f5f9}.description-content{font-size:14px;line-height:1.6;color:#475569}.text-muted{color:#94a3b8;font-style:italic}.task-attachments-card{background:#fff;border-radius:12px;padding:20px;border:1px solid #e2e8f0}.count-badge{margin-left:auto;background:var(--color-primary, #1e40af);color:#fff;font-size:10px;padding:2px 8px;border-radius:10px;font-weight:800}.attachments-list-modern{display:flex;flex-direction:column;gap:8px}.attachment-item-modern{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#f8fafc;border-radius:8px;transition:all .2s}.attachment-item-modern:hover{background:#f1f5f9}.attachment-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.file-icon-modern{width:40px;height:40px;border-radius:8px;background:rgba(var(--color-primary-rgb, 30, 64, 175),.1);border:1px solid rgba(var(--color-primary-rgb, 30, 64, 175),.2);display:flex;align-items:center;justify-content:center;color:var(--color-primary, #1e40af);flex-shrink:0}.file-info{flex:1;min-width:0}.file-name{font-size:13px;font-weight:600;color:#0f172a;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.file-type{font-size:10px;font-weight:700;color:#94a3b8;letter-spacing:.5px}.attachment-actions{display:flex;gap:4px}.icon-btn{width:32px;height:32px;border-radius:6px;border:none;background:transparent;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.icon-btn:hover{background:#e2e8f0;color:#0f172a}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px}.loading-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.task-modal-content{max-width:100%;max-height:100vh;border-radius:0}.task-modal-body{padding:20px}.info-card-row{grid-template-columns:1fr;gap:12px}.task-title-modern{font-size:20px}}.resource-tab-container{width:100%;display:flex;flex-direction:column;gap:1.5rem;height:100%}.resource-tab-content{display:flex;gap:1.5rem;height:100%;overflow:hidden}.resource-tab-content.split-view .resource-list-section{flex:0 0 50%;overflow-y:auto}.resource-list-section{flex:1;display:flex;flex-direction:column;gap:1.5rem}.resource-detail-section{flex:0 0 50%;background:#fff;border-radius:12px;border:1px solid #e2e8f0;display:flex;flex-direction:column;overflow:hidden;max-height:100%}.resource-detail-header{padding:20px 24px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;background:#fff;position:sticky;top:0;z-index:10;flex-shrink:0}.resource-detail-header h3{margin:0;font-size:16px;font-weight:700;color:#0f172a}.close-detail-btn{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;border:none;background:#f8fafc;color:#64748b;cursor:pointer;transition:all .2s}.close-detail-btn:hover{background:#fee2e2;color:#ef4444;transform:rotate(90deg)}.resource-detail-content{flex:1;overflow-y:auto;background:#f8fafc}.resource-table tbody tr.selected{background:rgba(var(--color-primary-rgb, 30, 64, 175),.08);border-left:3px solid var(--color-primary, #1e40af)}.resource-tab-header{display:flex;justify-content:space-between;align-items:center;gap:2rem;flex-wrap:wrap}.resource-tab-title-section{display:flex;align-items:center;gap:.75rem}.resource-tab-title{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0}.resource-tab-count{display:inline-flex;align-items:center;padding:.375rem .75rem;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);border-radius:20px;font-size:.875rem;font-weight:600}.resource-search-section{display:flex;gap:.75rem;align-items:center;flex:1;max-width:600px}.resource-search-box{position:relative;flex:1;min-width:200px}.resource-search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:#94a3b8;pointer-events:none}.resource-search-box input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1px solid #e2e8f0;border-radius:10px;font-size:.875rem;color:#1e293b;background:#fff;transition:all .2s cubic-bezier(.4,0,.2,1)}.resource-search-box input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.resource-search-box input::placeholder{color:#94a3b8}.resource-category-filter{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:10px;font-size:.875rem;font-weight:500;color:#475569;background:#fff;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);min-width:150px}.resource-category-filter:hover{border-color:var(--color-primary)}.resource-category-filter:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.1)}.resource-table-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden}.resource-table{width:100%;border-collapse:collapse}.resource-table tbody tr{cursor:pointer}.resource-table thead{background:#f8fafc;border-bottom:1px solid #e2e8f0}.resource-table thead th{padding:1rem 1.25rem;text-align:left;font-size:.75rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.resource-table-action-header{text-align:center!important}.resource-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .2s cubic-bezier(.4,0,.2,1)}.resource-table tbody tr:last-child{border-bottom:none}.resource-table tbody tr:hover{background:#f8fafc}.resource-table tbody td{padding:1.25rem;font-size:.875rem;color:#475569;vertical-align:middle}.resource-title-cell{display:flex;align-items:center;gap:.75rem}.resource-icon{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.resource-title-text{font-weight:600;color:#1e293b;line-height:1.4}.resource-type-cell{display:flex;align-items:center;gap:.5rem}.type-icon-small{color:#64748b;flex-shrink:0}.resource-visibility-badge{display:inline-flex;padding:.375rem .75rem;background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary);border-radius:6px;font-size:.8125rem;font-weight:600;white-space:nowrap}.resource-tags-cell{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.resource-tag{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:#f1f5f9;color:#475569;border-radius:6px;font-size:.8125rem;font-weight:500;white-space:nowrap}.resource-tag svg{flex-shrink:0}.resource-actions-cell{display:flex;gap:.5rem;justify-content:center;align-items:center}.resource-open-btn,.resource-download-btn{width:40px;height:40px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.resource-open-btn:hover,.resource-download-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:scale(1.05)}@media(max-width:1024px){.resource-tab-header{flex-direction:column;align-items:stretch}.resource-search-section{max-width:none}}@media(max-width:768px){.resource-tab-title{font-size:1.25rem}.resource-table thead th{padding:.75rem 1rem;font-size:.6875rem}.resource-table tbody td{padding:1rem}.resource-actions-cell{flex-wrap:wrap}.resource-tags-cell{max-width:200px}}@media(max-width:640px){.resource-tab-title-section{flex-direction:column;align-items:flex-start}.resource-search-section{flex-direction:column}.resource-category-filter{width:100%}.resource-table{font-size:.8125rem}.resource-title-cell{flex-direction:column;align-items:flex-start}.resource-tags-cell{max-width:150px}}.attendance-tab-container{width:100%;display:flex;flex-direction:column;gap:1.5rem;transition:opacity .3s cubic-bezier(.4,0,.2,1)}.attendance-tab-container.updating{opacity:.6;pointer-events:none}.attendance-tab-container.updating .attendance-table-wrapper{position:relative}.attendance-tab-container.updating .attendance-table-wrapper:after{content:"";position:absolute;inset:0;background:#ffffff80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);border-radius:12px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:.5}50%{opacity:.8}}.attendance-tab-header{display:flex;justify-content:space-between;align-items:center;gap:2rem;padding:1.5rem;background:#fff;border:1px solid #e2e8f0;border-radius:12px}.attendance-week-nav-btn{width:44px;height:44px;border-radius:10px;border:1px solid #e2e8f0;background:#fff;color:#64748b;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0}.attendance-week-nav-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary);transform:scale(1.05)}.attendance-week-nav-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.attendance-week-info{flex:1;display:flex;flex-direction:column;align-items:center;gap:.5rem}.attendance-week-label{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.attendance-week-dates{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:700;color:#1e293b}.attendance-week-dates svg{color:var(--color-primary);flex-shrink:0}.attendance-table-wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow-x:auto}.attendance-table{width:100%;border-collapse:collapse;min-width:1200px}.attendance-table thead{background:#f8fafc;border-bottom:2px solid #e2e8f0}.attendance-table thead th{padding:1rem;text-align:center;font-size:.75rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.05em;vertical-align:middle}.attendance-time-header{text-align:left!important;position:sticky;left:0;background:#f8fafc;z-index:10;border-right:2px solid #e2e8f0}.attendance-time-header{display:flex;align-items:center;gap:.5rem;justify-content:center}.attendance-day-header{min-width:150px}.day-header-content{display:flex;flex-direction:column;gap:.25rem}.day-name{font-size:.875rem;font-weight:700;color:#1e293b}.day-date{font-size:.75rem;font-weight:500;color:#94a3b8;text-transform:none}.attendance-table tbody tr{border-bottom:1px solid #f1f5f9;transition:background-color .2s cubic-bezier(.4,0,.2,1)}.attendance-table tbody tr:last-child{border-bottom:none}.attendance-table tbody tr:hover{background:#f8fafc}.attendance-table tbody td{padding:1rem;font-size:.875rem;color:#475569;vertical-align:top;text-align:center}.attendance-time-cell{position:sticky;left:0;background:#fff;z-index:5;border-right:2px solid #f1f5f9;text-align:left!important;font-weight:600;color:#475569}.attendance-table tbody tr:hover .attendance-time-cell{background:#f8fafc}.time-range{display:flex;flex-direction:column;gap:.25rem;align-items:flex-start}.time-range span{font-size:.8125rem}.time-separator{color:#cbd5e1;margin:0 .25rem}.attendance-session-cell{padding:.75rem!important}.session-card{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;text-align:left;min-height:140px;transition:all .2s cubic-bezier(.4,0,.2,1)}.session-card:hover{background:#fff;border-color:var(--color-primary);box-shadow:0 4px 12px rgba(var(--color-primary-rgb),.15)}.session-subject{font-weight:700;font-size:.9375rem;color:#1e293b;line-height:1.3}.session-teacher{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:#64748b}.session-teacher svg{flex-shrink:0;color:#94a3b8}.attendance-status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .625rem;border-radius:6px;font-size:.75rem;font-weight:700;white-space:nowrap;align-self:flex-start}.attendance-status-badge svg{flex-shrink:0}.attendance-status-badge.present{background:#dcfce7;color:#16a34a}.attendance-status-badge.absent{background:#fee2e2;color:#dc2626}.attendance-status-badge.late{background:#fef3c7;color:#d97706}.attendance-status-badge.excused{background:#dbeafe;color:#2563eb}.session-actions{display:flex;flex-direction:row;gap:.5rem;margin-top:auto}.session-join-btn,.session-recordings-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem .75rem;border:none;border-radius:8px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.session-join-btn{background:var(--color-primary);color:#fff}.session-join-btn:hover{background:#1a4d8c;transform:translateY(-1px);box-shadow:0 4px 8px rgba(var(--color-primary-rgb),.3)}.session-recordings-btn{background:#fff;color:var(--color-primary);border:1px solid var(--color-primary)}.session-recordings-btn:hover{background:var(--color-primary);color:#fff;transform:translateY(-1px);box-shadow:0 4px 8px rgba(var(--color-primary-rgb),.2)}.session-join-btn svg,.session-recordings-btn svg{flex-shrink:0}.session-join-btn:disabled,.session-recordings-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;pointer-events:none}.spinner-small{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.session-recordings-btn .spinner-small{border:2px solid rgba(26,86,166,.3);border-top-color:var(--color-primary)}.session-recordings-btn:disabled .spinner-small{border:2px solid rgba(255,255,255,.3);border-top-color:#fff}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.attendance-break-cell{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #fbbf24}.break-content{display:flex;align-items:center;justify-content:center;gap:.5rem;font-weight:700;color:#d97706;font-size:.875rem}.break-content svg{flex-shrink:0}.attendance-no-session-cell{background:#f1f5f9;border:1px solid #e2e8f0}.no-session-content{display:flex;align-items:center;justify-content:center;gap:.5rem;font-weight:600;color:#94a3b8;font-size:.8125rem;font-style:italic}.no-session-content svg{flex-shrink:0}.attendance-empty-cell{background:#fafafa}@media(max-width:1024px){.attendance-tab-header{padding:1rem}.attendance-week-dates{font-size:1rem}.attendance-table{min-width:1000px}}@media(max-width:768px){.attendance-tab-header{flex-direction:column;gap:1rem}.attendance-week-nav-btn{width:40px;height:40px}.attendance-week-info{width:100%}.attendance-table thead th{padding:.75rem .5rem;font-size:.6875rem}.attendance-table tbody td{padding:.75rem .5rem}.session-card{padding:.75rem;min-height:100px}.session-subject{font-size:.875rem}.session-teacher{font-size:.75rem}.attendance-day-header{min-width:120px}}@media(max-width:640px){.attendance-table{min-width:800px}.attendance-week-dates{font-size:.875rem;flex-wrap:wrap;justify-content:center}.session-card{padding:.625rem;gap:.375rem}.session-join-btn{padding:.375rem .625rem;font-size:.75rem}}.group-details-container{border:1px solid var(--color-border);background:var(--color-card);border-radius:var(--radius-md);padding:20px;min-height:calc(100% - 42px)}.group-details-header{display:flex;flex-direction:column;gap:10px;padding:10px 20px;border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:1px 1px 3px var(--shadow-card)}.group-details-header-main{display:flex;align-items:center}.group-details-back-btn{all:unset;display:flex;align-items:center;gap:5px;background-color:var(--color-text-secondary);border:1px solid var(--color-border);color:var(--color-text-inverse);cursor:pointer;padding:6px 8px;border-radius:var(--radius-sm);font-size:var(--font-size-button);font-weight:500}.group-details-back-btn:hover{color:var(--color-text-inverse)}.group-details-header-title-container{display:flex;flex-direction:column;margin-left:20px}.group-details-header-title-container .header-title{font-size:var(--font-size-secondary-text);font-weight:600}.group-details-header-title-container .header-id-mode-container{display:flex;gap:15px;font-size:var(--font-size-secondary-text);font-weight:500;color:var(--color-text-secondary)}.group-details-header-title-container .header-mode{display:flex;align-items:center;gap:6px}.group-details-header-title-container .header-id-mode-container .mode-dot{width:8px;height:8px;background-color:var(--color-text-secondary);border-radius:50%;display:inline-block}.group-details-tab-container{display:flex;gap:15px;padding:10px 20px;margin-top:20px;border-radius:var(--radius-md);border:1px solid var(--color-border);box-shadow:1px 1px 3px var(--shadow-card)}.group-details-tab{all:unset;padding:8px 15px;border-radius:var(--radius-sm);font-size:var(--font-size-button);font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:.2s background-color,.4s color}.group-details-tab.active,.group-details-tab:hover{background-color:var(--color-accent);color:var(--color-text-inverse)}.grp-details-main-content{padding:20px;margin-top:10px;border-radius:var(--radius-md)}.grp-details-main-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:15px}.grp-main-header-title-container{display:flex;align-items:center;gap:10px}.grp-main-header-title-container h3{margin:0}.grp-main-header-title-container .items-count{font-size:var(--font-size-secondary-text);color:var(--color-text-secondary)}.grp-main-table{border-collapse:separate;border-spacing:0;overflow:hidden;width:100%;border:1px solid var(--color-border);border-radius:10px}.grp-main-table tr:first-child th:first-child,.grp-main-table tr:first-child td:first-child{border-top-left-radius:10px}.grp-main-table tr:first-child th:last-child,.grp-main-table tr:first-child td:last-child{border-top-right-radius:10px}.grp-main-table tr:last-child td:first-child{border-bottom-left-radius:10px}.grp-main-table tr:last-child td:last-child{border-bottom-right-radius:10px}.grp-main-table thead{background-color:var(--color-bg);font-size:var(--font-size-secondary-text);font-weight:600;text-align:left}.grp-main-table th{padding:15px;border-bottom:1px solid var(--color-border)}.grp-main-table h4{margin:0}.grp-main-table td{font-size:var(--font-size-table);border-bottom:1px solid var(--color-border);padding:15px;min-height:100px}.grp-main-table .grp-main-table-tag{display:inline-block;font-size:var(--font-size-caption);font-weight:600;border-radius:var(--radius-lg);padding:5px;background-color:#efe4ff;color:#33047a;border:1px solid rgb(207,180,248);margin-right:5px;margin-top:5px}.group-details-panel{position:fixed;top:0;right:-450px;width:450px;height:100vh;background:#fff;box-shadow:-10px 0 50px #0a2e5d26;transition:right .5s cubic-bezier(.165,.84,.44,1);z-index:1001;display:flex;flex-direction:column;border-left:1px solid rgba(10,46,93,.1)}.group-details-panel.open{right:0}.group-details-header{padding:1.5rem;background:var(--color-primary);background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);color:#fff;display:flex;align-items:center;justify-content:space-between;box-shadow:0 4px 12px #0a2e5d33;z-index:10}.group-details-header h2{margin:0;font-size:1.25rem;font-weight:800;color:#fff;letter-spacing:-.02em}.close-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.2);color:#fff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);-webkit-backdrop-filter:none;backdrop-filter:none}.close-btn:hover{background:#ffffff4d;transform:rotate(90deg)}.group-details-body{flex:1;overflow-y:auto;padding:1.5rem;background:#f8fafc;background-image:radial-gradient(circle at 100% 100%,#f1f5f9 0,transparent 25%),radial-gradient(circle at 0% 0%,#f1f5f9 0,transparent 25%)}.group-details-body::-webkit-scrollbar{width:5px}.group-details-body::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:10px}.group-info-section{text-align:center;padding-bottom:2rem;border-bottom:2px solid rgba(10,46,93,.05);margin-bottom:2rem}.group-avatar-large{width:140px;height:140px;border-radius:30%;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem;font-size:56px;font-weight:800;box-shadow:0 10px 30px #0a2e5d40;border:5px solid white;transform:rotate(-3deg);transition:transform .3s ease}.group-avatar-large:hover{transform:rotate(0) scale(1.05)}.group-avatar-large img{width:100%;height:100%;border-radius:inherit;object-fit:cover}.group-name-section{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:10px}.group-name-section h3{margin:0;font-size:24px;font-weight:800;color:var(--color-primary);letter-spacing:-.02em}.edit-btn{background:#f1f5f9;border:1px solid rgba(10,46,93,.1);color:var(--color-primary);padding:8px 16px;border-radius:12px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;transition:all .2s cubic-bezier(.175,.885,.32,1.275)}.edit-btn:hover{background:var(--color-primary);color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #0a2e5d33}.group-description{color:#64748b;font-size:15px;font-weight:500;line-height:1.5;max-width:90%;margin:10px auto}.group-meta{color:#94a3b8;font-size:13px;font-weight:600;margin-top:5px}.participants-section{margin-bottom:2rem}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem}.section-header h4{margin:0;font-size:17px;font-weight:800;color:var(--color-primary);display:flex;align-items:center;gap:10px}.add-participant-btn{background:var(--color-accent);background:linear-gradient(135deg,var(--color-accent) 0%,#f97316 100%);color:#fff;border:none;padding:10px 20px;border-radius:14px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;transition:all .3s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 4px 12px #e0591e4d}.add-participant-btn:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 16px #e0591e66}.participants-list{display:flex;flex-direction:column;gap:10px}.participant-item{display:flex;align-items:center;gap:15px;padding:1rem;background:#fff;border-radius:18px;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000000a;border:1px solid rgba(10,46,93,.03)}.participant-item:hover{background:#f8fafc;transform:translate(5px);box-shadow:0 8px 25px #0a2e5d14}.participant-avatar{width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;flex-shrink:0;box-shadow:0 4px 10px #0a2e5d26}.participant-info{flex:1;min-width:0}.participant-name{font-weight:700;font-size:15px;color:var(--color-primary);display:flex;align-items:center;gap:8px;flex-wrap:wrap;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.you-badge{background:#3b82f6;color:#fff;font-size:10px;padding:2px 8px;border-radius:8px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 2px 6px #3b82f64d}.admin-badge{background:#10b981;color:#fff;font-size:10px;padding:2px 8px;border-radius:8px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:4px;box-shadow:0 2px 6px #10b9814d}.admin-badge svg{color:inherit}.participant-role{font-size:12px;font-weight:600;color:#94a3b8;margin-top:2px}.participant-actions{display:flex;gap:8px;opacity:0;transform:translate(10px);transition:all .3s ease}.participant-item:hover .participant-actions{opacity:1;transform:translate(0)}.action-btn{background:#f1f5f9;border:1px solid rgba(10,46,93,.1);color:var(--color-primary);width:36px;height:36px;border-radius:10px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.175,.885,.32,1.275)}.action-btn:hover{background:var(--color-primary);color:#fff!important;transform:scale(1.1)}.action-btn svg{display:inline-block;color:inherit;stroke:currentColor!important;stroke-width:2.5px;width:18px!important;height:18px!important;min-width:18px;min-height:18px}.make-admin-btn:hover{background:#10b981;color:#fff}.revoke-admin-btn{background:#fee2e2;color:#ef4444}.revoke-admin-btn:hover{background:#ef4444;color:#fff!important}.group-remove-btn{background:#fee2e2;color:#ef4444!important}.group-remove-btn:hover{background:#ef4444;color:#fff!important}.group-actions-section{padding-top:1.5rem;border-top:2px solid rgba(10,46,93,.05);display:flex;flex-direction:column;gap:12px}.action-button{width:100%;padding:14px;border:none;border-radius:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;font-size:15px;font-weight:700;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.leave-btn{background:#fff7ed;color:#ea580c;border:1px solid rgba(234,88,12,.1)}.leave-btn:hover{background:#ea580c;color:#fff;transform:translateY(-2px);box-shadow:0 4px 15px #ea580c40}.delete-btn{background:#fef2f2;color:#ef4444;border:1px solid rgba(239,68,68,.1)}.delete-btn:hover{background:#ef4444;color:#fff;transform:translateY(-2px);box-shadow:0 4px 15px #ef444440}@media(max-width:768px){.group-details-panel{width:100%;right:-100%}.group-details-panel.open{right:0}}.chats-page{height:calc(100vh - 105px);overflow:hidden}.chats-container{display:flex;height:100%;background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);overflow:hidden;box-shadow:0 20px 60px #0a2e5d1f;border:1px solid rgba(10,46,93,.05)}.chats-sidebar{width:380px;border-right:1px solid rgba(10,46,93,.08);display:flex;flex-direction:column;background:#fff}.chats-sidebar-header{padding:15px 30px;background:#fff;border-bottom:1px solid rgba(10,46,93,.05);display:flex;justify-content:space-between;align-items:center}.chats-sidebar-header h2{margin:0;font-size:26px;font-weight:800;color:var(--color-primary);letter-spacing:-.02em}.btn-new-group{background:var(--color-accent);background:linear-gradient(135deg,var(--color-accent) 0%,#f97316 100%);border:none;color:#fff;width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 4px 12px #e0591e4d}.btn-new-group:hover{transform:scale(1.1) rotate(90deg);box-shadow:0 6px 16px #e0591e66}.chats-tabs{display:flex;background:#fff;padding:5px;margin:10px 15px;background:#f1f5f9;border-radius:12px}.chat-tab{flex:1;padding:10px;border:none;background:transparent;display:flex;align-items:center;justify-content:center;gap:10px;cursor:pointer;color:#64748b;font-weight:600;font-size:14px;border-radius:10px;transition:all .25s ease}.chat-tab:hover{color:var(--color-primary)}.chat-tab.active{color:var(--color-primary);background:#fff;box-shadow:0 4px 12px #0000000d}.unread-badge{background:var(--color-accent);color:#fff;font-size:10px;padding:2px 6px;border-radius:8px;font-weight:700;box-shadow:0 2px 6px #e0591e4d}.chats-search{padding:15px 20px;background:#fff;display:flex;align-items:center;gap:12px;position:relative}.chats-search input{flex:1;background:#f1f5f9;border:1px solid transparent;padding:12px 18px 12px 42px;border-radius:12px;font-size:14px;font-weight:500;outline:none;transition:all .3s ease;color:var(--color-text-primary)}.chats-search input:focus{background:#fff;border-color:var(--color-primary);box-shadow:0 0 0 4px #0a2e5d14}.chats-search svg{position:absolute;left:35px;color:#94a3b8;pointer-events:none}.chats-loading{padding:40px;text-align:center;color:#7f8c8d}.chat-list{flex:1;overflow-y:auto;padding:10px 0}.chat-list::-webkit-scrollbar{width:4px}.chat-list::-webkit-scrollbar-thumb{background:#0a2e5d1a;border-radius:10px}.chat-list-empty{padding:40px 20px;text-align:center;color:#7f8c8d}.chat-list-empty p{margin:0 0 5px;font-weight:500}.chat-list-empty span{font-size:13px;color:#95a5a6}.chat-list-item{display:flex;align-items:center;gap:15px;padding:12px 20px;margin:4px 15px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border-radius:14px;border:1px solid transparent}.chat-list-item:hover{background:#f8fafc;transform:translate(5px)}.chat-list-item.selected{background:#0a2e5d0d;border-color:#0a2e5d1a}.chat-avatar{width:54px;height:54px;border-radius:18px;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;flex-shrink:0;box-shadow:0 4px 12px #0a2e5d33}.chat-info{flex:1;min-width:0}.chat-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.chat-name{margin:0;font-size:16px;font-weight:700;color:var(--color-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-time{font-size:11px;font-weight:600;color:#94a3b8;flex-shrink:0}.chat-preview{display:flex;justify-content:space-between;align-items:center}.chat-last-message{margin:0;font-size:13.5px;font-weight:500;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.chat-unread-count{background:var(--color-accent);color:#fff;font-size:10px;padding:2px 8px;border-radius:8px;font-weight:700;flex-shrink:0;margin-left:10px;box-shadow:0 4px 10px #e0591e4d}.chats-main{flex:1;display:flex;flex-direction:column;background:#fff;position:relative}.chats-empty-state{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#94a3b8;gap:20px;text-align:center;padding:40px}.chats-empty-state svg{color:var(--color-primary);opacity:.15;animation:floating 3s ease-in-out infinite}@keyframes floating{0%,to{transform:translateY(0)}50%{transform:translateY(-15px)}}.chats-empty-state h3{margin:0;font-size:22px;font-weight:700;color:var(--color-primary);opacity:.8}.chats-empty-state p{margin:0;font-size:15px;max-width:300px;line-height:1.5}.chat-conversation{flex:1;display:flex;flex-direction:column;height:100%}.conversation-header{padding:18px 25px;background:#fffc;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid rgba(10,46,93,.08);display:flex;justify-content:space-between;align-items:center;z-index:10}.conversation-header-info{display:flex;align-items:center;gap:15px}.conversation-avatar{width:48px;height:48px;border-radius:16px;background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;box-shadow:0 4px 12px #0a2e5d33}.conversation-details h3{margin:0;font-size:18px;font-weight:700;color:var(--color-primary);letter-spacing:-.01em}.participant-count{font-size:12px;font-weight:600;color:#94a3b8}.btn-more{background:#f1f5f9;border:none;color:#64748b;cursor:pointer;width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;transition:all .2s}.btn-more:hover{background:var(--color-primary);color:#fff}.conversation-messages{flex:1;overflow-y:auto;padding:25px;background:#f8fafc;background-image:radial-gradient(circle at 100% 100%,#f1f5f9 0,transparent 25%),radial-gradient(circle at 0% 0%,#f1f5f9 0,transparent 25%);display:flex;flex-direction:column}.messages-loading,.messages-empty{text-align:center;padding:40px;color:#7f8c8d}.messages-empty span{font-size:13px;color:#95a5a6}.messages-loading-more{text-align:center;padding:10px;font-size:12px;color:var(--color-primary);background:#ffffffb3;border-radius:20px;margin-bottom:10px;position:sticky;top:0;z-index:10}.wp-chat-message{display:flex;flex-direction:column;margin-bottom:8px;width:100%;background:transparent!important;animation:wpMessageSlideIn .3s ease}@keyframes wpMessageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.wp-chat-message-sent{align-self:flex-end}.wp-chat-message-received{align-self:flex-start}.wp-chat-message-sender-name{font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;opacity:.8}.wp-chat-message-bubble-container{position:relative;display:flex;flex-direction:column;width:100%}.wp-chat-message-sent .wp-chat-message-bubble-container{align-items:flex-end}.wp-chat-message-received .wp-chat-message-bubble-container{align-items:flex-start}.wp-chat-message-bubble{padding:12px 18px;border-radius:18px;position:relative;word-wrap:break-word;word-break:break-word;display:block;width:fit-content;max-width:50%;min-width:60px;box-shadow:0 4px 15px #0000000a;transition:all .2s;z-index:2}.wp-chat-message-sent .wp-chat-message-bubble{background:var(--color-primary);background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);border-bottom-right-radius:4px;color:#fff}.wp-chat-message-sent .wp-chat-message-text{color:#fff}.wp-chat-message-sent .wp-chat-message-time{color:#ffffffd9}.wp-chat-message-received .wp-chat-message-bubble{background:#fff;border-bottom-left-radius:4px;border:1px solid rgba(10,46,93,.05)}.wp-reply-preview-bubble{background:#0000000d;border-left:3px solid var(--color-primary);padding:6px 10px;border-radius:6px;margin-bottom:8px;font-size:13px;cursor:pointer;transition:background .2s}.wp-reply-preview-bubble:hover{background:#00000014}.wp-chat-message-sent .wp-reply-preview-bubble{background:#ffffff26;border-left-color:#fff;color:#fff}.wp-chat-message-sent .wp-reply-preview-bubble:hover{background:#fff3}.wp-reply-preview-bubble strong{display:block;margin-bottom:2px;font-size:12px;color:inherit}.wp-reply-preview-bubble p{margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;color:inherit;opacity:.9}.wp-chat-message-text{font-size:15px;line-height:1.6;color:inherit;word-break:break-word}.wp-chat-message-footer{display:flex;justify-content:flex-end;align-items:center;margin-top:4px;min-height:16px}.wp-chat-message-time{font-weight:600;font-size:10px;letter-spacing:.02em;opacity:.85;white-space:nowrap;-webkit-user-select:none;user-select:none}.wp-message-actions{display:flex;gap:8px;opacity:0;position:absolute;bottom:-32px;padding:6px 12px;background:#fffffff2;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:20px;box-shadow:0 4px 12px #00000026;transition:all .2s cubic-bezier(.175,.885,.32,1.275);transform:scale(.8) translateY(-10px);z-index:99;pointer-events:none}.wp-chat-message-sent .wp-message-actions{right:0}.wp-chat-message-received .wp-message-actions{left:0}.wp-chat-message-bubble-container:hover .wp-message-actions{opacity:1;transform:scale(1) translateY(0);pointer-events:all}.wp-message-actions button{background:transparent;border:none;color:#444;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.wp-message-actions button:hover{background:#f0f2f5;color:var(--color-primary);transform:scale(1.1)}.wp-message-edit-mode{display:flex;flex-direction:column;gap:8px;min-width:200px}.wp-message-edit-mode input{width:100%;padding:8px 12px;border:1px solid rgba(255,255,255,.3);border-radius:8px;background:#ffffff1a;color:inherit;font-size:14px;outline:none}.wp-chat-message-received .wp-message-edit-mode input{border-color:#ddd;background:#f9f9f9}.wp-edit-actions{display:flex;justify-content:flex-end;gap:8px}.wp-edit-actions button{width:28px;height:28px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.wp-btn-save-edit{background:#27ae60;color:#fff}.wp-btn-cancel-edit{background:#e74c3c;color:#fff}.wp-edited-label{font-size:10px;font-style:italic;opacity:.6;margin-right:4px}.chat-message-sent .message-actions button{background:#fff3}.message-actions button:hover{background:#0003}.chat-message-sent .message-actions button:hover{background:#ffffff4d}.deleted-text{font-style:italic;opacity:.7}.message-deleted .chat-message-bubble{opacity:.8}.reply-preview-bubble{background:#0000000d;border-left:3px solid var(--color-primary);padding:5px 8px;border-radius:4px;margin-bottom:5px;font-size:13px}.chat-message-sent .reply-preview-bubble{background:#ffffff1a;border-left-color:#fff}.reply-preview-bubble strong{display:block;font-size:11px;margin-bottom:2px}.reply-preview-bubble p{margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.9}.chat-input-wrapper{background:#fff;border-top:1px solid #e0e0e0}.replying-preview{padding:10px 20px;background:#f8f9fa;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e0e0e0;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}.replying-info{flex:1;min-width:0}.replying-info span{font-size:12px;color:var(--color-primary);display:block;margin-bottom:2px}.replying-info p{margin:0;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#7f8c8d}.btn-close-reply{background:transparent;border:none;color:#95a5a6;cursor:pointer;padding:5px;display:flex;align-items:center}.btn-close-reply:hover{color:#e74c3c}.conversation-input{padding:20px 25px;background:#fff;border-top:1px solid rgba(10,46,93,.08);display:flex;gap:15px;align-items:center}.conversation-input input{flex:1;background:#f1f5f9;border:2px solid #f1f5f9;padding:14px 24px;border-radius:28px;font-size:15px;font-weight:500;outline:none;transition:all .3s ease;box-shadow:inset 0 2px 4px #00000008}.conversation-input input:focus{background:#fff;border-color:var(--color-primary);box-shadow:0 0 0 4px #0a2e5d14}.conversation-input button{width:48px;height:48px;border-radius:50%;border:none;background:var(--color-primary);background:linear-gradient(135deg,var(--color-primary) 0%,#1a4d8c 100%);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 4px 12px #0a2e5d4d;padding:0;flex-shrink:0}.conversation-input button svg{stroke-width:2.5px;transition:transform .3s ease}.conversation-input button:hover:not(:disabled){transform:scale(1.1) rotate(5deg);box-shadow:0 8px 20px #0a2e5d66;background:linear-gradient(135deg,#1a4d8c 0%,var(--color-primary) 100%)}.conversation-input button:hover:not(:disabled) svg{transform:translate(2px) translateY(-2px)}.conversation-input button:active:not(:disabled){transform:scale(.9)}.conversation-input button:disabled{opacity:.5;cursor:not-allowed;background:#cbd5e1;box-shadow:none}@media(max-width:768px){.chats-page{padding:0}.chats-container{border-radius:0;height:100vh}.chats-sidebar{width:100%}.chats-main{position:absolute;inset:0;z-index:10}.chat-message{max-width:95%}}.chat-search-results{flex:1;overflow-y:auto}.search-section{margin-bottom:10px}.search-section-title{padding:12px 20px;font-size:13px;font-weight:600;color:var(--color-primary);background:rgba(var(--color-primary-rgb),.1);text-transform:uppercase;letter-spacing:.5px}.user-list{background:#fff}.user-list-item{display:flex;gap:12px;padding:15px 20px;cursor:pointer;transition:background .2s;border-bottom:1px solid #f0f0f0;align-items:center}.user-list-item:hover{background:#f8f9fa}.user-info{flex:1;min-width:0}.user-name{margin:0 0 4px;font-size:16px;font-weight:600;color:#2c3e50}.user-type{font-size:13px;color:#95a5a6}.new-chat-badge{background:var(--color-primary);color:#fff;font-size:11px;padding:4px 10px;border-radius:12px;font-weight:600}.meeting-shell{height:100vh;width:100vw;overflow:hidden;background:#0b1220;position:relative;padding:0;margin:0}.meeting-frame-wrapper{width:100%;height:100%;display:block}.meeting-frame-card{width:100%;height:100%;border:none;background:#000;position:relative}.meeting-frame-card iframe{border:none;width:100%;height:100%;display:block}.meeting-fab-back,.meeting-fab-refresh{position:fixed;width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#0f172ab3;color:#fff;border:1px solid rgba(255,255,255,.15);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);cursor:pointer;z-index:999;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #0000004d}.meeting-fab-back{top:20px;left:20px}.meeting-fab-refresh{bottom:20px;right:20px}.meeting-fab-back:hover,.meeting-fab-refresh:hover{background:#1e293be6;transform:scale(1.1);border-color:#ffffff4d;box-shadow:0 0 15px #ffffff1a}.meeting-loading{position:absolute;inset:0;display:grid;place-items:center;background:#0b1220;color:#e2e8f0;font-weight:600;z-index:100}.meeting-room-empty{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0b1220;color:#e2e8f0;text-align:center;gap:12px;padding:20px}.meeting-room-empty h3{margin:0;font-size:1.5rem}.meeting-room-empty p{opacity:.7}
