:root{--color-bg:#f6f7fb;--color-surface:#fff;--color-surface-subtle:#fafbfc;--color-border:#eaecf0;--color-border-strong:#d0d5dd;--color-text:#101828;--color-text-muted:#667085;--color-text-subtle:#98a2b3;--color-primary:#f59e0b;--color-primary-hover:#d97706;--color-primary-contrast:#1a1a1a;--color-primary-soft:#fffaeb;--color-primary-soft-hover:#fef3c7;--color-primary-accent:#92400e;--color-success:#067647;--color-success-soft:#ecfdf3;--color-warning:#b54708;--color-warning-soft:#fffaeb;--color-danger:#b42318;--color-danger-soft:#fef3f2;--color-info:#175cd3;--color-info-soft:#eff8ff;--shadow-xs:0 1px 2px #1018280d;--shadow-sm:0 1px 3px #1018280f,0 1px 2px #1018280a;--shadow-md:0 4px 8px -2px #1018280f,0 2px 4px -2px #10182808;--shadow-lg:0 12px 24px -6px #10182814,0 4px 8px -4px #10182808;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px}*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f6f7fb;background-color:var(--color-bg);color:#101828;color:var(--color-text);font-family:Inter,Nunito Sans,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;font-size:14px;line-height:1.5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#d0d5dd;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#98a2b3}.ds-btn{align-items:center;border:1px solid #0000;border-radius:8px;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:inherit;font-size:13.5px;font-weight:600;gap:6px;justify-content:center;line-height:1.2;padding:9px 16px;text-decoration:none;transition:background-color .12s ease,border-color .12s ease,color .12s ease,box-shadow .12s ease,transform .08s ease;white-space:nowrap}.ds-btn:focus-visible{outline:2px solid #f59e0b;outline:2px solid var(--color-primary);outline-offset:2px}.ds-btn:disabled,.ds-btn[aria-disabled=true]{cursor:not-allowed;opacity:.55;pointer-events:none}.ds-btn-sm{border-radius:6px;border-radius:var(--radius-sm);font-size:12.5px;padding:6px 12px}.ds-btn-lg{font-size:14.5px;padding:11px 20px}.ds-btn-primary{background:#f59e0b;background:var(--color-primary);border-color:#f59e0b;border-color:var(--color-primary);box-shadow:0 1px 2px #1018280d;box-shadow:var(--shadow-xs);color:#1a1a1a;color:var(--color-primary-contrast)}.ds-btn-primary:hover:not(:disabled){background:#d97706;background:var(--color-primary-hover);border-color:#d97706;border-color:var(--color-primary-hover);box-shadow:0 1px 3px #1018280f,0 1px 2px #1018280a;box-shadow:var(--shadow-sm)}.ds-btn-primary:active:not(:disabled){transform:translateY(1px)}.ds-btn-secondary{background:#fff;background:var(--color-surface);border-color:#eaecf0;border-color:var(--color-border);color:#101828;color:var(--color-text)}.ds-btn-secondary:hover:not(:disabled){background:#fafbfc;background:var(--color-surface-subtle);border-color:#d0d5dd;border-color:var(--color-border-strong)}.ds-btn-ghost{background:#0000;border-color:#0000;color:#667085;color:var(--color-text-muted)}.ds-btn-ghost:hover:not(:disabled){background:#fafbfc;background:var(--color-surface-subtle);color:#101828;color:var(--color-text)}.ds-btn-danger{background:#fff;background:var(--color-surface);border-color:#fecdca;color:#b42318;color:var(--color-danger)}.ds-btn-danger:hover:not(:disabled){background:#fef3f2;background:var(--color-danger-soft);border-color:#fda29b}.ds-btn-primary-soft{background:#fffaeb;background:var(--color-primary-soft);border-color:#fde68a;color:#92400e;color:var(--color-primary-accent)}.ds-btn-primary-soft:hover:not(:disabled){background:#fef3c7;background:var(--color-primary-soft-hover);border-color:#f59e0b;border-color:var(--color-primary)}.crm-select,select:not([data-no-style]){appearance:none;background-color:#fff;background-color:var(--color-surface);background-image:url("data:image/svg+xml;utf8,<svg xmlns=%27http://www.w3.org/2000/svg%27 width=%2712%27 height=%2712%27 viewBox=%270 0 24 24%27 fill=%27none%27 stroke=%27%236b7280%27 stroke-width=%272.4%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27><polyline points=%276 9 12 15 18 9%27/></svg>");background-position:right 12px center;background-repeat:no-repeat;background-size:12px 12px;border:1px solid #d0d5dd;border:1px solid var(--color-border-strong,#d0d5dd);border-radius:10px;box-shadow:0 1px 1px #0f172a05;color:#101828;color:var(--color-text);cursor:pointer;font-family:inherit;font-size:13.5px;line-height:1.3;min-height:38px;outline:none;padding:9px 36px 9px 14px;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.crm-select:hover:not(:disabled),select:not([data-no-style]):hover:not(:disabled){border-color:#b8bcc6}.crm-select:focus,select:not([data-no-style]):focus{border-color:#f59e0b;border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b2e}.crm-select:disabled,select:not([data-no-style]):disabled{background-color:#f8f9fb;color:#98a2b3;color:var(--color-text-subtle);cursor:not-allowed;opacity:.7}.crm-input,input:where([type=text],[type=search],[type=number],[type=email],[type=password],[type=tel],[type=url],[type=date],[type=datetime-local],[type=time]):not([data-no-style]),textarea:not([data-no-style]){background:#fff;background:var(--color-surface);border:1px solid #d0d5dd;border:1px solid var(--color-border-strong,#d0d5dd);border-radius:10px;box-sizing:border-box;color:#101828;color:var(--color-text);font-family:inherit;font-size:13.5px;line-height:1.4;min-height:38px;outline:none;padding:9px 12px;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.crm-input-block,.exam-form input,.exam-form textarea,.settings-field input,.settings-field textarea{width:100%}textarea:not([data-no-style]){line-height:1.55;min-height:88px;resize:vertical}.crm-input:hover:not(:disabled):not(:focus),input:where([type=text],[type=search],[type=number],[type=email],[type=password],[type=tel],[type=url],[type=date],[type=datetime-local],[type=time]):not([data-no-style]):hover:not(:disabled):not(:focus),textarea:not([data-no-style]):hover:not(:disabled):not(:focus){border-color:#b8bcc6}.crm-input:focus,input:where([type=text],[type=search],[type=number],[type=email],[type=password],[type=tel],[type=url],[type=date],[type=datetime-local],[type=time]):not([data-no-style]):focus,textarea:not([data-no-style]):focus{border-color:#f59e0b;border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b2e}input:where([type=text],[type=search],[type=number],[type=email],[type=password],[type=tel],[type=url],[type=date],[type=datetime-local],[type=time]):not([data-no-style])::placeholder,textarea:not([data-no-style])::placeholder{color:#98a2b3;color:var(--color-text-subtle);opacity:1}input:where([type=text],[type=search],[type=number],[type=email],[type=password],[type=tel],[type=url],[type=date],[type=datetime-local],[type=time]):not([data-no-style]):disabled,textarea:not([data-no-style]):disabled{background:#f8f9fb;color:#98a2b3;color:var(--color-text-subtle);cursor:not-allowed}input[type=number]:not([data-no-style])::-webkit-inline-spin-button,input[type=number]:not([data-no-style])::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]:not([data-no-style]){-moz-appearance:textfield}input[type=checkbox]:not([data-no-style]),input[type=radio]:not([data-no-style]){accent-color:#f59e0b;accent-color:var(--color-primary);cursor:pointer;height:16px;width:16px}.courses-select,.filter-select,.form-select,.month-selector{appearance:none!important;background-image:url("data:image/svg+xml;utf8,<svg xmlns=%27http://www.w3.org/2000/svg%27 width=%2712%27 height=%2712%27 viewBox=%270 0 24 24%27 fill=%27none%27 stroke=%27%236b7280%27 stroke-width=%272.4%27 stroke-linecap=%27round%27 stroke-linejoin=%27round%27><polyline points=%276 9 12 15 18 9%27/></svg>")!important;background-position:right 12px center!important;background-repeat:no-repeat!important;background-size:12px 12px!important;border:1px solid #d0d5dd!important;border:1px solid var(--color-border-strong,#d0d5dd)!important;border-radius:10px!important;padding:9px 36px 9px 14px!important}.ds-search{align-items:center;background:#fff;background:var(--color-surface);border:1px solid #eaecf0;border:1px solid var(--color-border);border-radius:8px;border-radius:var(--radius-md);display:inline-flex;gap:8px;min-width:240px;padding:8px 12px;transition:border-color .12s ease,box-shadow .12s ease}.ds-search:focus-within{border-color:#f59e0b;border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1f}.ds-search svg{color:#98a2b3;color:var(--color-text-subtle);flex-shrink:0}.ds-search input{background:#0000;border:0;color:#101828;color:var(--color-text);flex:1 1;font-family:inherit;font-size:13.5px;outline:0}.ds-search input::placeholder{color:#98a2b3;color:var(--color-text-subtle)}.ds-spinner{animation:ds-spin .7s linear infinite;border:2.5px solid #eaecf0;border-top-color:#f59e0b;border:2.5px solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);display:inline-block;height:20px;width:20px}@keyframes ds-spin{to{transform:rotate(1turn)}}.ds-loading{font-size:13.5px;gap:10px;padding:48px 20px}.ds-empty,.ds-loading{align-items:center;color:#667085;color:var(--color-text-muted);display:flex;justify-content:center}.ds-empty{background:#fff;background:var(--color-surface);border:1px dashed #d0d5dd;border:1px dashed var(--color-border-strong);border-radius:12px;border-radius:var(--radius-lg);flex-direction:column;gap:12px;padding:56px 28px;text-align:center}.ds-empty-icon{align-items:center;background:#fffaeb;background:var(--color-primary-soft);border:1px solid #fde68a;border-radius:50%;color:#f59e0b;color:var(--color-primary);display:flex;height:56px;justify-content:center;margin-bottom:4px;width:56px}.ds-empty h3{color:#101828;color:var(--color-text);font-size:15px;font-weight:600;margin:0}.ds-empty p{color:#667085;color:var(--color-text-muted);font-size:13px;line-height:1.5;margin:0;max-width:340px}.modal-overlay{animation:modal-fade-in .2s ease both;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#0f172a6b!important}.modal-content{animation:modal-pop-in .28s cubic-bezier(.2,.8,.2,1) both;border-radius:16px!important;box-shadow:0 24px 64px -12px #0f172a73,0 8px 16px -4px #0f172a1f!important}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-pop-in{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{border-bottom:1px solid #eaecf0!important;border-bottom:1px solid var(--color-border)!important;padding:20px 24px!important}.modal-header h3{color:#101828!important;color:var(--color-text)!important;font-size:16px!important;font-weight:700!important;letter-spacing:-.1px}.modal-body{color:#101828;color:var(--color-text);font-size:13.5px;line-height:1.6;padding:18px 24px!important}.modal-body p{margin:0 0 8px}.modal-body p:last-child{margin-bottom:0}.modal-warning{background:#fef3f2;background:var(--color-danger-soft);border-left:3px solid #b42318;border-left:3px solid var(--color-danger);border-radius:8px;color:#b42318!important;color:var(--color-danger)!important;font-size:12.5px!important;margin-top:10px!important;padding:10px 12px}.modal-actions{background:#fafbfc;background:var(--color-surface-subtle);border-top:1px solid #eaecf0!important;border-top:1px solid var(--color-border)!important;gap:10px!important;padding:14px 24px!important}.modal-actions .btn-cancel,.modal-actions .btn-confirm-delete,.modal-actions .btn-danger,.modal-actions .btn-primary,.modal-actions .btn-secondary{border-radius:10px!important;cursor:pointer;font-family:inherit!important;font-size:13px!important;font-weight:600!important;padding:9px 18px!important;transition:background-color .18s ease,border-color .18s ease,transform .18s ease,box-shadow .18s ease,color .18s ease}.modal-actions .btn-cancel,.modal-actions .btn-secondary{background:#fff;background:var(--color-surface);border:1px solid #d0d5dd;border:1px solid var(--color-border-strong);color:#101828;color:var(--color-text)}.modal-actions .btn-cancel:hover:not(:disabled),.modal-actions .btn-secondary:hover:not(:disabled){background:#fafbfc;background:var(--color-surface-subtle);border-color:#b8bcc6;transform:translateY(-1px)}.modal-actions .btn-primary{background:#f59e0b;background:var(--color-primary);border:1px solid #f59e0b;border:1px solid var(--color-primary);box-shadow:0 2px 6px -2px #f59e0b66;color:#1a1a1a;color:var(--color-primary-contrast)}.modal-actions .btn-primary:hover:not(:disabled){background:#d97706;background:var(--color-primary-hover);box-shadow:0 6px 16px -4px #f59e0b80;transform:translateY(-1px)}.modal-actions .btn-confirm-delete,.modal-actions .btn-danger{background:#b42318;background:var(--color-danger);border:1px solid #b42318;border:1px solid var(--color-danger);box-shadow:0 2px 6px -2px #b4231866;color:#fff}.modal-actions .btn-confirm-delete:hover:not(:disabled),.modal-actions .btn-danger:hover:not(:disabled){background:#912018;border-color:#912018;box-shadow:0 6px 16px -4px #b4231880;transform:translateY(-1px)}@media (prefers-reduced-motion:reduce){.modal-actions button,.modal-content,.modal-overlay{animation:none!important;transition:none!important}}.ds-badge{align-items:center;border:1px solid #0000;border-radius:999px;display:inline-flex;font-size:11.5px;font-weight:600;letter-spacing:.1px;padding:3px 10px;text-transform:capitalize}.ds-badge-success{background:#ecfdf3;background:var(--color-success-soft);border-color:#abefc6;color:#067647;color:var(--color-success)}.ds-badge-warning{background:#fffaeb;background:var(--color-warning-soft);border-color:#fedf89;color:#b54708;color:var(--color-warning)}.ds-badge-danger{background:#fef3f2;background:var(--color-danger-soft);border-color:#fecdca;color:#b42318;color:var(--color-danger)}.ds-badge-info{background:#eff8ff;background:var(--color-info-soft);border-color:#b2ddff;color:#175cd3;color:var(--color-info)}.ds-badge-neutral{background:#fafbfc;background:var(--color-surface-subtle);border-color:#eaecf0;border-color:var(--color-border);color:#667085;color:var(--color-text-muted)}table[class*=table]:not([data-no-polish]){border-collapse:initial;border-spacing:0;font-size:13px;width:100%}table[class*=table]:not([data-no-polish]) thead th{background:#fafbfc;background:var(--color-surface-subtle);border-bottom:1px solid #eaecf0;border-bottom:1px solid var(--color-border);color:#667085;color:var(--color-text-muted);font-size:11px;font-weight:600;letter-spacing:.6px;padding:12px 16px;position:sticky;text-align:left;text-transform:uppercase;top:0;white-space:nowrap;z-index:1}table[class*=table]:not([data-no-polish]) tbody td{border-bottom:1px solid #eaecf0;border-bottom:1px solid var(--color-border);color:#101828;color:var(--color-text);padding:14px 16px;transition:background-color .12s ease;vertical-align:middle}table[class*=table]:not([data-no-polish]) tbody tr{transition:background-color .12s ease,transform .12s ease}table[class*=table]:not([data-no-polish]) tbody tr:hover{background-color:#fffaeb;background-color:var(--color-primary-soft)}table[class*=table]:not([data-no-polish]) tbody tr:hover td{background-color:initial}table[class*=table]:not([data-no-polish]) tbody tr:last-child td{border-bottom:none}table[class*=table]:not([data-no-polish]) tbody tr{animation:ds-row-fade-in .32s cubic-bezier(.2,.8,.2,1) both}@keyframes ds-row-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}table[class*=table]:not([data-no-polish]) tbody tr:first-child{animation-delay:0ms}table[class*=table]:not([data-no-polish]) tbody tr:nth-child(2){animation-delay:30ms}table[class*=table]:not([data-no-polish]) tbody tr:nth-child(3){animation-delay:60ms}table[class*=table]:not([data-no-polish]) tbody tr:nth-child(4){animation-delay:90ms}table[class*=table]:not([data-no-polish]) tbody tr:nth-child(5){animation-delay:.12s}table[class*=table]:not([data-no-polish]) tbody tr:nth-child(6){animation-delay:.15s}table[class*=table]:not([data-no-polish]) tbody tr:nth-child(7){animation-delay:.18s}table[class*=table]:not([data-no-polish]) tbody tr:nth-child(8){animation-delay:.21s}table[class*=table]:not([data-no-polish]) tbody tr:nth-child(9){animation-delay:.24s}table[class*=table]:not([data-no-polish]) tbody tr:nth-child(10){animation-delay:.27s}table[class*=table]:not([data-no-polish]) tbody tr:nth-child(11){animation-delay:.3s}table[class*=table]:not([data-no-polish]) tbody tr:nth-child(12){animation-delay:.33s}.course-lessons,.course-modules,.cq-page,.dashboard,.order-lists-page,.page-transition,.students-page,.team-page,[class$=-page]>h1:first-child{animation:ds-page-in .36s cubic-bezier(.2,.8,.2,1) both}@keyframes ds-page-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}[role=button]:focus-visible,a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{border-radius:6px;border-radius:var(--radius-sm);outline:2px solid #f59e0b;outline:2px solid var(--color-primary);outline-offset:2px}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}.sidebar{background-color:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;gap:2px;height:100vh;overflow-y:auto;padding:18px 14px 14px;position:relative;scrollbar-color:var(--color-border) #0000;scrollbar-width:thin;width:248px}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--color-border-strong)}.sidebar-logo{border-bottom:1px solid var(--color-border);margin-bottom:14px;padding:6px 10px 22px}.logo-text{font-family:Inter,Nunito Sans,sans-serif;gap:10px}.logo-mark,.logo-text{align-items:center;display:inline-flex}.logo-mark{background:linear-gradient(135deg,#fbbf24 0,var(--color-primary-hover) 100%);border-radius:8px;box-shadow:0 4px 8px -2px #f59e0b59;color:var(--color-primary-contrast);font-family:inherit;font-size:16px;font-weight:800;height:30px;justify-content:center;letter-spacing:-.5px;transition:transform .22s cubic-bezier(.2,.8,.2,1),box-shadow .22s ease;width:30px}.sidebar-logo:hover .logo-mark{box-shadow:0 6px 12px -2px #f59e0b73;transform:rotate(-4deg) scale(1.05)}.logo-name{color:var(--color-text);font-size:16px;font-weight:700;letter-spacing:-.3px}.logo-sub{border:1px solid var(--color-border);border-radius:4px;color:var(--color-text-subtle);font-size:10px;font-weight:700;letter-spacing:1px;padding:2px 6px;text-transform:uppercase}.sidebar-menu{display:flex;flex-direction:column;gap:2px;padding:0}.sidebar-item{align-items:center;border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;display:flex;font-size:13.5px;font-weight:500;letter-spacing:0;overflow:hidden;padding:9px 12px;position:relative;text-decoration:none;transition:background-color .18s ease,color .18s ease,transform .22s cubic-bezier(.2,.8,.2,1)}.sidebar-item:before{background:var(--color-primary);border-radius:0 3px 3px 0;content:"";height:60%;left:0;position:absolute;top:50%;transform:translateY(-50%) scaleY(0);transform-origin:center;transition:transform .24s cubic-bezier(.2,.8,.2,1);width:3px}.sidebar-item:hover{background-color:var(--color-surface-subtle);color:var(--color-text);transform:translateX(2px)}.sidebar-item:active{transform:translateX(2px) scale(.99)}.sidebar-item.active{background-color:var(--color-primary-soft);color:var(--color-primary-accent);font-weight:600;transform:translateX(0)}.sidebar-item.active:before{transform:translateY(-50%) scaleY(1)}.sidebar-icon{align-items:center;display:flex;flex-shrink:0;height:18px;justify-content:center;margin-right:10px;opacity:.85;transition:opacity .18s ease,transform .24s cubic-bezier(.2,.8,.2,1);width:18px}.sidebar-icon svg{stroke:currentColor;height:18px;width:18px}.sidebar-item:hover .sidebar-icon{opacity:1;transform:scale(1.08)}.sidebar-item.active .sidebar-icon{opacity:1;transform:scale(1.05)}.sidebar-item.active .sidebar-icon svg{stroke:var(--color-primary-accent)}.sidebar-item.active .sidebar-icon svg [fill=currentColor]{fill:var(--color-primary-accent)}.sidebar-label{flex:1 1}.sidebar-divider{background-color:var(--color-border);height:1px;margin:14px 8px}.sidebar-section-title{color:var(--color-text-subtle);font-size:10.5px;font-weight:700;letter-spacing:.8px;padding:14px 12px 6px;text-transform:uppercase}.sidebar-logout{align-items:center;background:none;border:none;border-radius:var(--radius-md);border-top:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;display:flex;font-family:inherit;font-size:13.5px;font-weight:500;margin-top:14px;padding:14px 12px 12px;text-align:left;transition:background-color .18s ease,color .18s ease;width:100%}.sidebar-logout:hover{background-color:var(--color-danger-soft);color:var(--color-danger)}.sidebar-logout:hover .sidebar-icon{transform:translateX(2px)}@media (prefers-reduced-motion:reduce){.logo-mark,.sidebar-icon,.sidebar-item,.sidebar-item:before{transition:none!important}}.topbar{align-items:center;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;gap:16px;height:64px;justify-content:space-between;padding:0 24px}.topbar-breadcrumb{display:flex;flex-direction:column;gap:2px;min-width:0}.topbar-breadcrumb .crumb-eyebrow{color:var(--color-text-subtle);font-size:11px;font-weight:600;letter-spacing:.6px;text-transform:uppercase}.topbar-breadcrumb .crumb-title{color:var(--color-text);font-size:15px;font-weight:600;line-height:1.2}.topbar-right{gap:12px}.profile-section,.topbar-right{align-items:center;display:flex}.profile-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:999px;gap:10px;padding:6px 10px}.profile-image{object-fit:cover}.profile-avatar-fallback,.profile-image{border-radius:50%;height:32px;width:32px}.profile-avatar-fallback{align-items:center;background:linear-gradient(135deg,#fbbf24 0,var(--color-primary-hover) 100%);color:var(--color-primary-contrast);display:flex;font-size:12px;font-weight:700;justify-content:center}.profile-info{display:flex;flex-direction:column;line-height:1.1}.profile-name{color:var(--color-text);font-size:13px;font-weight:600}.profile-role{color:var(--color-text-muted);font-size:11px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.layout{background-color:var(--color-surface);display:flex;height:100vh;width:100%}.main-content{background-color:var(--color-bg);display:flex;flex:1 1;flex-direction:column;overflow:hidden}.content-area{flex:1 1;overflow-y:auto;padding:0}.teacher-sidebar .sidebar-logo{align-items:center;display:flex;gap:8px}.teacher-badge{background-color:#e8f5e9;border-radius:4px;color:#2e7d32;font-size:10px;letter-spacing:.5px;padding:2px 6px;text-transform:uppercase}.coming-soon-page{align-items:center;background:#f5f6fa;display:flex;justify-content:center;min-height:70vh;padding:32px}.coming-soon-card{background:#fff;border-radius:20px;box-shadow:0 4px 24px #00000012;max-width:440px;padding:56px 48px;text-align:center;width:100%}.coming-soon-icon{display:flex;justify-content:center;margin-bottom:24px}.coming-soon-title{color:#202224;font-size:26px;font-weight:700;margin-bottom:12px}.coming-soon-description{color:#777;font-size:15px;line-height:1.6;margin-bottom:28px}.coming-soon-badge{background:#eef0ff;border-radius:20px;color:var(--color-primary);display:inline-block;font-size:13px;font-weight:600;letter-spacing:.04em;padding:8px 22px}.metric-card{align-items:flex-start;animation:mc-fade-in .36s cubic-bezier(.2,.8,.2,1) both;background:var(--color-surface,#fff);border:1px solid #ececef;border:1px solid var(--color-border,#ececef);border-radius:14px;border-radius:var(--radius-lg,14px);box-shadow:0 1px 2px #0f172a0a;overflow:hidden;padding:18px;position:relative;transition:transform .22s cubic-bezier(.2,.8,.2,1),box-shadow .22s ease,border-color .22s ease}.metric-card:before{background:radial-gradient(420px circle at 50% -20%,#f5a6231a,#0000 40%);background:radial-gradient(420px circle at var(--mc-x,50%) var(--mc-y,-20%),#f5a6231a,#0000 40%);content:"";inset:0;opacity:0;pointer-events:none;position:absolute;transition:opacity .22s ease}.metric-card:hover{border-color:#e0e3e9;box-shadow:0 8px 20px -10px #0f172a2e,0 2px 4px #0f172a0d}.metric-card:hover:before{opacity:1}.metric-icon{background:#fff7ec;background:var(--color-primary-soft,#fff7ec);color:#f5a623;color:var(--color-primary,#f5a623);height:44px;position:relative;transition:transform .22s cubic-bezier(.2,.8,.2,1);width:44px}.metric-card:hover .metric-icon{transform:scale(1.05) rotate(-2deg)}.metric-icon svg{stroke:currentColor;height:20px;width:20px}.metric-details{gap:4px;min-width:0}.metric-title{color:#6b7280;color:var(--color-text-muted,#6b7280);font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.metric-value{font-feature-settings:"tnum";color:#111827;color:var(--color-text,#111827);font-size:26px;font-variant-numeric:tabular-nums;letter-spacing:-.4px;line-height:1.1}.metric-trend{align-items:center;border-radius:999px;display:inline-flex;font-size:11px;font-weight:600;gap:4px;margin-top:2px;padding:2px 8px;width:fit-content}.metric-trend.is-up{background:#ebfaf1;color:#1f9d6b}.metric-trend.is-down{background:#fdeeee;color:#d6464a}.metric-change{align-items:center;color:#6b7280;color:var(--color-text-muted,#6b7280);display:flex;font-size:12px;font-weight:500;gap:6px}.metric-change .change-text{letter-spacing:.1px}.metric-sparkline{color:#f5a623;color:var(--color-primary,#f5a623);height:28px;margin-top:8px;width:100%}.mc-variant-primary .metric-icon{background:#fff7ec;color:#f5a623}.mc-variant-success .metric-icon{background:#ebfaf1;color:#1f9d6b}.mc-variant-danger .metric-icon{background:#fdeeee;color:#d6464a}.mc-variant-info .metric-icon{background:#eaf3ff;color:#3a72e0}.mc-skel{pointer-events:none}.mc-skel-block{background:#eef0f3;border-radius:8px;overflow:hidden;position:relative}.mc-skel-block:after{animation:mc-shimmer 1.4s ease-in-out infinite;background:linear-gradient(90deg,#0000,#fff9,#0000);content:"";inset:0;position:absolute;transform:translateX(-100%)}.mc-skel .metric-icon{background:#eef0f3;color:#0000}.mc-skel-line{height:12px}.mc-skel-line.short{width:50%}.mc-skel-line.big{height:22px;width:70%}@keyframes mc-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes mc-shimmer{to{transform:translateX(100%)}}@media (prefers-reduced-motion:reduce){.mc-skel-block:after,.metric-card,.metric-icon{animation:none!important;transition:none!important}}@supports (background-attachment:fixed){.metric-card{will-change:transform}}.page-empty-state{align-items:center;animation:pes-fade-in .32s cubic-bezier(.2,.8,.2,1) both;background:#fafafb;border:1px dashed #e6e8ed;border-radius:14px;color:#6b7280;display:flex;flex-direction:column;gap:10px;padding:56px 24px;text-align:center}.pes-sm{border-radius:10px;gap:6px;padding:28px 16px}.pes-lg{background:#0000;border:none;padding:80px 24px}.pes-illu{animation:pes-bob 4.2s ease-in-out infinite;margin-bottom:6px;transform-origin:center bottom;will-change:transform}.pes-sm .pes-illu svg{height:68px;width:84px}.pes-lg .pes-illu svg{height:134px;width:168px}.pes-title{color:#1f2937;font-size:16px;font-weight:600;letter-spacing:-.1px;margin:4px 0 0}.pes-lg .pes-title{font-size:20px}.pes-sm .pes-title{font-size:14px}.pes-desc{color:#6b7280;font-size:13px;line-height:1.5;margin:0;max-width:380px}.pes-lg .pes-desc{font-size:14px;max-width:460px}.pes-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:14px}.pes-btn{border-radius:8px;font-weight:600}.pes-btn,.pes-btn-ghost{font-size:13px;padding:9px 18px}.pes-btn-ghost{background:#0000;border:1px solid #e6e8ed;border-radius:8px;color:#4b5563;cursor:pointer;font-weight:500;transition:background .15s ease,border-color .15s ease,color .15s ease}.pes-btn-ghost:hover{background:#f5f6f8;border-color:#d6d9df;color:#1f2937}.pes-variant-error{background:#fff8f7;border-color:#f4caca}.pes-variant-success{background:#f3fbf6;border-color:#c2e9d3}.pes-variant-search{background:#fdfaf3;border-color:#f0dfb6}@keyframes pes-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes pes-bob{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-4px) rotate(-1deg)}}@media (prefers-reduced-motion:reduce){.page-empty-state,.pes-illu{animation:none}}.dashboard{background-color:var(--color-bg);min-height:100%;padding:24px 28px}.dashboard-header{align-items:flex-end;display:flex;justify-content:space-between;margin-bottom:20px}.dashboard-title{color:var(--color-text);font-size:22px;font-weight:700;letter-spacing:-.2px}.dashboard-error{background:var(--color-danger-soft);border:1px solid #fecdca;border-radius:var(--radius-md);color:var(--color-danger);padding:12px 14px}.dashboard-loading{color:var(--color-text-muted);font-size:14px;padding:60px 24px;text-align:center}.chart-empty{align-items:center;color:var(--color-text-subtle);display:flex;font-size:13px;height:260px;justify-content:center}.metrics-grid{grid-gap:16px;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}@media (max-width:1200px){.metrics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.metrics-grid{grid-template-columns:1fr}}.payment-section,.sales-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);margin-bottom:20px;padding:20px 22px}.section-header{margin-bottom:16px}.month-selector,.section-title{color:var(--color-text)}.month-selector{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-family:inherit;font-size:13px;outline:none;padding:7px 12px}.month-selector:hover{border-color:var(--color-border-strong)}.payment-table{overflow-x:auto}.payment-table table{border-collapse:collapse;width:100%}.payment-table th{background:var(--color-surface-subtle);color:var(--color-text-muted);font-size:12px;font-weight:600;letter-spacing:.4px;padding:10px 12px;text-align:left;text-transform:uppercase}.payment-table td,.payment-table th{border-bottom:1px solid var(--color-border)}.payment-table td{color:var(--color-text);font-size:13.5px;padding:12px}.payment-table tr:last-child td{border-bottom:0}.status-badge{background:var(--color-surface-subtle);border:1px solid var(--color-border);color:var(--color-text-muted)}.status-badge.completed{background:var(--color-success-soft);border-color:#abefc6;color:var(--color-success)}.status-badge.pending,.status-badge.processing{background:var(--color-warning-soft);border-color:#fedf89;color:var(--color-warning)}.status-badge.cancelled,.status-badge.failed{background:var(--color-danger-soft);border-color:#fecdca;color:var(--color-danger)}.status-badge.refunded{background:var(--color-info-soft);border-color:#b2ddff;color:var(--color-info)}.course-card{animation:cc-in .38s cubic-bezier(.2,.8,.2,1) both;background:#fff;background:var(--color-surface,#fff);border:1px solid #ececef;border:1px solid var(--color-border,#ececef);border-radius:16px;box-shadow:0 1px 2px #0f172a0a;cursor:default;display:flex;flex-direction:column;overflow:hidden;position:relative;transition:box-shadow .24s ease,border-color .24s ease,transform .28s cubic-bezier(.2,.8,.2,1)}.course-card[role=button]{cursor:pointer}.course-card:hover{border-color:#e1e4eb;border-color:var(--color-border-strong,#e1e4eb);box-shadow:0 16px 32px -12px #0f172a2e,0 4px 8px #0f172a0a;transform:translateY(-3px)}@keyframes cc-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.cc-hero{aspect-ratio:16/9;background:linear-gradient(135deg,#fffaeb,#fde6c1);overflow:hidden;position:relative}.cc-img{display:block;height:100%;object-fit:cover;transition:transform .7s cubic-bezier(.2,.8,.2,1);width:100%;will-change:transform}.course-card:hover .cc-img{transform:scale(1.05)}.cc-hero-shade{background:linear-gradient(180deg,#0f172a2e,#0f172a00 35%,#0f172a00 60%,#0f172a80);inset:0}.cc-hero-shade,.cc-top-row{pointer-events:none;position:absolute}.cc-top-row{display:flex;gap:8px;justify-content:space-between;left:12px;right:12px;top:12px}.cc-owner,.cc-status{align-items:center;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:#ffffffeb;border-radius:999px;box-shadow:0 1px 2px #0f172a14;display:inline-flex;font-size:11px;font-weight:600;gap:6px;letter-spacing:.2px;padding:4px 10px 4px 8px}.cc-status.is-live{color:#1f9d6b}.cc-status.is-draft{color:#b45309}.cc-status-dot{animation:cc-pulse 2.2s ease-in-out infinite;background:currentColor;border-radius:50%;box-shadow:0 0 0 0 currentColor;height:7px;width:7px}@keyframes cc-pulse{0%,to{box-shadow:0 0 0 0 currentColor;opacity:.85}50%{box-shadow:0 0 0 4px #0000;opacity:1}}.cc-owner{color:#1f9d6b}.cc-play{align-items:center;display:flex;filter:drop-shadow(0 6px 18px rgba(15,23,42,.35));inset:0;justify-content:center;opacity:0;pointer-events:none;position:absolute;transform:scale(.9);transition:opacity .24s ease,transform .24s cubic-bezier(.2,.8,.2,1)}.course-card:hover .cc-play{opacity:1;transform:scale(1)}.cc-price{align-items:center;border-radius:999px;bottom:12px;box-shadow:0 2px 6px #0f172a2e;display:inline-flex;font-size:11.5px;font-weight:700;left:12px;letter-spacing:.2px;padding:4px 10px;position:absolute}.cc-price.is-free{background:#ebfaf1;color:#0e7c4a}.cc-price.is-paid{background:#fff7ec;color:#b45309}.cc-body{display:flex;flex:1 1;flex-direction:column;gap:8px;padding:16px 18px 8px}.cc-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#111827;color:var(--color-text,#111827);display:-webkit-box;font-size:15px;font-weight:700;letter-spacing:-.15px;line-height:1.35;margin:0;min-height:2.7em;overflow:hidden}.cc-meta{color:#6b7280;color:var(--color-text-muted,#6b7280);display:flex;flex-wrap:wrap;font-size:12px;gap:10px 14px}.cc-meta-item{align-items:center;display:inline-flex;gap:5px}.cc-meta-item svg{opacity:.75}.cc-meta-owner{color:#9ca3af;color:var(--color-text-subtle,#9ca3af);font-size:11px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cc-actions{border-top:1px solid #f3f4f6;display:flex;gap:8px;margin-top:auto;padding:12px 18px 16px}.cc-btn{align-items:center;border:1px solid #0000;border-radius:10px;cursor:pointer;display:inline-flex;flex:1 1;font-family:inherit;font-size:12.5px;font-weight:600;gap:6px;justify-content:center;padding:9px 12px;transition:background-color .18s ease,border-color .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease}.cc-btn:active{transform:translateY(1px)}.cc-btn-edit{background:#fff7ec;border-color:#fde6c1;color:#b45309}.cc-btn-edit:hover{background:#fff0d4;border-color:#fbcc83;box-shadow:0 2px 6px #f59e0b2e;color:#92400e;transform:translateY(-1px)}.cc-btn-edit:focus-visible{outline:2px solid #f59e0b;outline-offset:2px}.cc-btn-delete{background:#fff;background:var(--color-surface,#fff);border-color:#fecdca;color:#b42318}.cc-btn-delete:hover{background:#fef3f2;border-color:#fda29b;box-shadow:0 2px 6px #b4231829;color:#912018;transform:translateY(-1px)}.cc-btn-delete:focus-visible{outline:2px solid #b42318;outline-offset:2px}.course-card.is-horizontal{flex-direction:row}.course-card.is-horizontal .cc-hero{aspect-ratio:auto;flex-shrink:0;width:200px}.course-card.is-horizontal .cc-body{padding:16px}.course-card.is-horizontal .cc-actions{border-top:0;flex-direction:column;padding:16px}@media (prefers-reduced-motion:reduce){.cc-btn,.cc-img,.cc-play,.cc-status-dot,.course-card{animation:none!important;transition:none!important}.course-card:hover,.course-card:hover .cc-img{transform:none}}@media (max-width:540px){.cc-actions{flex-direction:column}.cc-btn{width:100%}}.loading-state,.ls-skel-wrap{--ls-base:#eef0f3;--ls-shine:#ffffffa6;--ls-radius:8px;--ls-accent:var(--color-primary,#f5a623);--ls-text:#6b7280}.loading-state{align-items:center;animation:ls-fade-in .22s ease-out both;color:var(--ls-text);display:flex;flex-direction:column;font-size:14px;gap:14px;justify-content:center;padding:60px 20px}.loading-state.is-compact{font-size:13px;gap:10px;padding:20px 14px}.loading-state.is-fullscreen{backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);background:#ffffffd9;inset:0;position:fixed;z-index:9999}.loading-message{letter-spacing:.01em;margin:0;opacity:.85}.visually-hidden{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.loading-spinner{height:36px;position:relative;width:36px}.loading-spinner-ring,.loading-spinner:before{border:3px solid #0000;border-radius:50%;content:"";inset:0;position:absolute}.loading-spinner:before{border-color:var(--ls-base);opacity:.55}.loading-spinner-ring{animation:ls-spin .72s cubic-bezier(.5,.1,.5,.9) infinite;border-right-color:var(--ls-accent);border-top-color:var(--ls-accent);box-shadow:0 0 24px -8px var(--ls-accent)}.loading-state.is-compact .loading-spinner{height:24px;width:24px}.loading-state.is-compact .loading-spinner-ring,.loading-state.is-compact .loading-spinner:before{border-width:2px}.loading-dots{display:inline-flex;gap:8px}.loading-dots span{animation:ls-dot-bounce .9s ease-in-out infinite;background:var(--ls-accent);border-radius:50%;height:9px;width:9px}.loading-dots span:nth-child(2){animation-delay:.12s}.loading-dots span:nth-child(3){animation-delay:.24s}.loading-bar{background:var(--ls-base);border-radius:999px;height:4px;max-width:80vw;overflow:hidden;position:relative;width:220px}.loading-bar-fill{animation:ls-bar 1.4s cubic-bezier(.4,0,.2,1) infinite;background:linear-gradient(90deg,#0000,var(--ls-accent),#0000);inset:0 auto 0 0;position:absolute;width:35%}.loading-pulse{animation:ls-pulse 1.1s ease-in-out infinite;background:var(--ls-accent);border-radius:50%;height:14px;width:14px}.ls-skel-wrap{animation:ls-fade-in .22s ease-out both;width:100%}.ls-skel-wrap.is-compact{padding:6px 0}.ls-skel-shimmer{background:var(--ls-base);border-radius:var(--ls-radius);overflow:hidden;position:relative}.ls-skel-shimmer:after{animation:ls-shimmer 1.4s ease-in-out infinite;background:linear-gradient(90deg,#0000 0,var(--ls-shine) 50%,#0000 100%);content:"";inset:0;position:absolute;transform:translateX(-100%)}.ls-skel-line{border-radius:6px;height:12px}.ls-skel-pill{border-radius:999px;height:22px;width:80px}.ls-skel-thumb{border-radius:var(--ls-radius);height:140px;width:100%}.ls-skel-avatar{border-radius:50%;flex-shrink:0;height:40px;width:40px}.ls-skel-input{border-radius:8px;height:38px;width:100%}.ls-skel-table{display:flex;flex-direction:column;gap:10px;padding:12px 0;width:100%}.ls-skel-row{grid-gap:16px;animation:ls-row-in .36s cubic-bezier(.2,.8,.2,1) both;background:#fff;border:1px solid #f1f2f4;border-radius:10px;display:grid;gap:16px;grid-template-columns:1.4fr 2fr 1fr 1fr 1fr;padding:14px 18px}.ls-skel-row-head{background:#0000;border:none;padding:8px 18px 0}.ls-skel-row-head .ls-skel-cell{height:10px;opacity:.6}.ls-skel-cell{border-radius:6px;height:14px}.ls-skel-cards{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));padding:6px 0}.ls-skel-card{animation:ls-card-in .38s cubic-bezier(.2,.8,.2,1) both;background:#fff;border:1px solid #f1f2f4;border-radius:12px;box-shadow:0 1px 2px #00000005;display:flex;flex-direction:column;gap:12px;padding:16px}.ls-skel-card .ls-skel-line{height:12px}.ls-skel-footer{display:flex;gap:8px;margin-top:auto;padding-top:4px}.ls-skel-list{display:flex;flex-direction:column;gap:8px;padding:6px 0}.ls-skel-list-item{align-items:center;animation:ls-row-in .32s cubic-bezier(.2,.8,.2,1) both;background:#fff;border:1px solid #f1f2f4;border-radius:10px;display:flex;gap:14px;padding:12px 16px}.ls-skel-list-body{flex:1 1;gap:8px}.ls-skel-form,.ls-skel-list-body{display:flex;flex-direction:column}.ls-skel-form{gap:18px;max-width:560px;padding:8px 0}.ls-skel-form-row{animation:ls-row-in .32s cubic-bezier(.2,.8,.2,1) both;gap:8px}.ls-skel-form-row,.ls-skel-page{display:flex;flex-direction:column}.ls-skel-page{gap:18px;padding:8px 0}.ls-skel-page-head{align-items:center;display:flex;justify-content:space-between;padding:4px 2px}.ls-skel-stats{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(3,1fr)}.ls-skel-stat{animation:ls-card-in .36s cubic-bezier(.2,.8,.2,1) both;background:#fff;border:1px solid #f1f2f4;border-radius:12px;display:flex;flex-direction:column;gap:10px;padding:18px}@media (max-width:700px){.ls-skel-stats{grid-template-columns:1fr}.ls-skel-row{grid-template-columns:1.5fr 1fr 1fr}.ls-skel-row .ls-skel-cell:nth-child(n+4){display:none}}@keyframes ls-spin{to{transform:rotate(1turn)}}@keyframes ls-dot-bounce{0%,80%,to{opacity:.5;transform:translateY(0)}40%{opacity:1;transform:translateY(-7px)}}@keyframes ls-bar{0%{left:-35%;width:35%}50%{width:55%}to{left:100%;width:35%}}@keyframes ls-pulse{0%,to{box-shadow:0 0 0 0 currentColor;opacity:.55;transform:scale(1)}50%{box-shadow:0 0 0 8px #0000;opacity:1;transform:scale(1.25)}}@keyframes ls-shimmer{0%{transform:translateX(-100%)}to{transform:translateX(100%)}}@keyframes ls-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}@keyframes ls-row-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes ls-card-in{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@media (prefers-reduced-motion:reduce){.loading-state,.ls-skel-card,.ls-skel-form-row,.ls-skel-list-item,.ls-skel-row,.ls-skel-stat,.ls-skel-wrap{animation:ls-fade-in .2s ease-out both!important}.ls-skel-shimmer:after{animation-duration:2.4s}.loading-spinner-ring{animation-duration:1.4s}.loading-bar-fill,.loading-dots span,.loading-pulse{animation-duration:2s}}.courses-page{background:var(--color-bg);min-height:100vh;padding:24px 28px}.courses-header{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:20px}.courses-header h1{color:var(--color-text);font-size:22px;font-weight:700;letter-spacing:-.2px;margin:0}.courses-tabs{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d;display:flex;gap:0;margin-bottom:30px;padding:8px;width:fit-content}.tab-button{background:#0000;border:none;border-radius:8px;color:#666;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s ease}.tab-button:hover{background:#f5f5f5;color:#333}.tab-button.active{background:#fef3e0;color:#1a1a1a}.courses-schedule{max-width:1200px}.page-subtitle{color:#1a1a1a;font-size:24px;font-weight:600;margin:0 0 30px}.courses-section{margin-bottom:40px}.section-header{background:#fff;border-radius:10px 10px 0 0;padding:14px 20px}.section-title{font-size:18px}.btn-create-video{border-radius:var(--radius-md);box-shadow:var(--shadow-xs);padding:9px 16px;transition:background-color .15s ease,box-shadow .15s ease}.btn-create-video:hover{box-shadow:var(--shadow-sm)}.courses-list{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding:4px 0}.courses-list>*{min-width:0}.courses-stats-strip{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));margin:4px 0 22px}.courses-stat{align-items:center;animation:cstat-in .32s cubic-bezier(.2,.8,.2,1) both;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;gap:12px;padding:14px 16px;transition:transform .22s cubic-bezier(.2,.8,.2,1),box-shadow .22s ease}.courses-stat:hover{box-shadow:0 8px 20px -10px #0f172a2e;transform:translateY(-2px)}.courses-stat-icon{align-items:center;border-radius:10px;display:inline-flex;flex-shrink:0;height:38px;justify-content:center;width:38px}.courses-stat-icon.is-total{background:#fff7ec;color:#b45309}.courses-stat-icon.is-live{background:#ebfaf1;color:#1f9d6b}.courses-stat-icon.is-draft{background:#fff4dc;color:#92400e}.courses-stat-icon.is-students{background:#eaf3ff;color:#3a72e0}.courses-stat-body{display:flex;flex-direction:column;min-width:0}.courses-stat-label{color:var(--color-text-muted);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.courses-stat-value{color:var(--color-text);font-size:22px;font-weight:700;letter-spacing:-.4px;line-height:1.1;margin-top:2px}@keyframes cstat-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.courses-page-title{color:var(--color-text);font-size:24px;font-weight:700;letter-spacing:-.4px;margin:0}.courses-page-sub{color:var(--color-text-muted);font-size:13px;margin:4px 0 0}.btn-create-video{align-items:center;background:var(--color-primary);border:1px solid var(--color-primary);border-radius:10px;box-shadow:0 2px 6px -2px #f59e0b4d;color:var(--color-primary-contrast);cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:6px;padding:10px 18px;transition:background-color .18s ease,box-shadow .18s ease,transform .18s ease}.btn-create-video:hover{background:var(--color-primary-hover);box-shadow:0 6px 16px -4px #f59e0b73;transform:translateY(-1px)}.btn-create-video:active{transform:translateY(0)}.courses-toolbar{border:1px solid var(--color-border);border-radius:12px;flex-wrap:wrap;gap:10px;margin-bottom:18px;padding:10px 12px}.courses-search,.courses-toolbar{align-items:center;background:var(--color-surface);display:flex}.courses-search{border:1px solid var(--color-border);border-radius:8px;flex:1 1 260px;gap:8px;max-width:360px;padding:8px 12px;transition:border-color .18s ease,box-shadow .18s ease}.courses-search:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b2e}.courses-search input{background:#0000;border:0;flex:1 1;font-family:inherit;font-size:13.5px;min-width:0;outline:none}.courses-search svg{color:var(--color-text-subtle);flex-shrink:0}.courses-results-meta{color:var(--color-text-muted);font-size:12px;margin-left:auto;padding:0 6px}.courses-pagination{align-items:center;display:flex;gap:12px;justify-content:center;margin-top:28px;padding:14px}.courses-pagination-btn{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;color:var(--color-text);cursor:pointer;font-family:inherit;font-size:13px;font-weight:500;padding:8px 14px;transition:background-color .16s ease,border-color .16s ease,transform .16s ease}.courses-pagination-btn:hover:not(:disabled){background:var(--color-surface-subtle);border-color:var(--color-border-strong);transform:translateY(-1px)}.courses-pagination-btn:disabled{cursor:not-allowed;opacity:.5}.courses-pagination-info{color:var(--color-text-muted);font-size:13px}.tab-content{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d;padding:40px}.tab-content h2{color:#1a1a1a;font-size:24px;font-weight:600;margin:0 0 16px}.tab-content p{color:#666;font-size:16px;margin:0}.modal-overlay{animation:fadeIn .2s ease}.modal-content{animation:slideUp .3s ease;border-radius:16px}.upload-modal{max-width:600px}.modal-header{border-bottom:1px solid #f0f0f0;padding:24px 24px 16px}.modal-close{color:#666;transition:color .2s ease}.modal-header h3{color:#1a1a1a;font-size:20px}.modal-body p{color:#333;font-size:15px;line-height:1.5;margin:0 0 12px}.modal-warning{color:#d32f2f;font-size:14px;margin:12px 0 0}.modal-actions{padding:16px 24px 24px}.btn-cancel,.btn-confirm-delete{font-weight:500;padding:10px 24px;transition:all .2s ease}.btn-cancel{border:1px solid #e0e0e0}.btn-cancel:hover{background:#f5f5f5}.btn-confirm-delete{background:#d32f2f;border:none}.btn-confirm-delete:hover{background:#c62828;box-shadow:0 4px 12px #d32f2f4d}.btn-primary{background:#ffc107;border:none;border-radius:8px;color:#1a1a1a;cursor:pointer;font-size:14px;font-weight:500;padding:10px 24px;transition:all .2s ease}.btn-primary:hover{background:#ffb300;box-shadow:0 4px 12px #ffc1074d}.upload-area{align-items:center;background:#fafafa;border:2px dashed #d0d0d0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;margin-bottom:24px;padding:40px;transition:all .3s ease}.upload-area:hover{background:#fffbf0;border-color:#ffc107}.upload-instruction{color:#333;font-size:16px;font-weight:500;margin:16px 0 8px}.upload-hint{color:#999;font-size:13px;margin:0}.form-group{margin-bottom:20px}.form-group input,.form-group textarea{border:1px solid #e0e0e0;border-radius:8px;box-sizing:border-box;padding:10px 14px;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus{border-color:#ffc107}.form-group textarea{min-height:80px}@media (max-width:768px){.courses-page{padding:20px}.courses-header h1{font-size:24px}.courses-tabs{flex-direction:column;width:100%}.section-header{align-items:flex-start;flex-direction:column;gap:12px}.btn-create-video{width:100%}.modal-content{margin:20px}}.courses-select{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-family:inherit;font-size:14px;outline:none;padding:9px 12px}.courses-select:focus{border-color:var(--color-primary)}.learning-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d;margin-bottom:16px;overflow:hidden}.section-header{align-items:center;background:#fafafa;border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;padding:10px 16px}.section-title{color:#1a1a1a;margin:0}.section-actions{align-items:center}.btn-delete,.btn-edit{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:6px;color:#666;cursor:pointer;display:flex;font-size:12px;gap:6px;padding:6px 12px;transition:all .2s ease}.btn-edit:hover{background:#fffbf0;border-color:#ffc107;color:#ffc107}.btn-delete:hover{background:#fee;border-color:#e53e3e;color:#e53e3e}.btn-delete svg,.btn-edit svg{color:currentColor}.section-content{padding:20px 16px}.form-field{margin-bottom:16px}.form-field,.select-wrapper{position:relative}.input-datetime,.select-input{background:#fff;border:1px solid #e0e0e0;border-radius:8px;box-sizing:border-box;cursor:pointer;font-family:inherit;font-size:14px;padding:10px 40px 10px 14px;transition:border-color .2s ease;width:100%}.input-datetime:focus,.select-input:focus{border-color:#ffc107;outline:none}select.select-input{appearance:none;-webkit-appearance:none;-moz-appearance:none}select.select-input optgroup{background:#f5f5f5;color:#999;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 0;text-transform:uppercase}select.select-input option{background:#fff;color:#333;font-size:14px;padding:8px 12px}.dropdown-icon{pointer-events:none;position:absolute;right:14px;top:50%;transform:translateY(-50%)}.input-with-icon{position:relative}.calendar-icon{left:14px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.input-datetime{padding-left:46px}.hint-text{color:#999;font-size:12px;margin:8px 0 0}.btn-save{background:#ffc107;color:#1a1a1a;font-weight:500;padding:10px 24px;transition:all .2s ease}.btn-save:hover{background:#ffb300;box-shadow:0 4px 12px #ffc1074d}.month-selector{border-top:1px solid #f0f0f0;margin-top:20px;padding-top:20px}.month-label{color:#666;font-size:13px;margin:0 0 12px}.month-buttons{display:flex;flex-wrap:wrap;gap:8px}.btn-month{background:#fff;border:1px solid #e0e0e0;border-radius:6px;color:#666;cursor:pointer;font-size:13px;font-weight:500;padding:4px 12px;transition:all .2s ease}.btn-month:hover{background:#fffbf0;border-color:#ffc107}.btn-month.active{background:#ffc107;border-color:#ffc107;color:#1a1a1a}.dropdown-menu{border:1px solid #e0e0e0;border-radius:8px;box-shadow:0 4px 12px #0000001a;max-height:200px;overflow-y:auto;top:calc(100% + 4px);z-index:100}.dropdown-section{padding:8px}.dropdown-section+.dropdown-section{border-top:1px solid #f0f0f0}.dropdown-label{color:#999;display:block;font-size:11px;letter-spacing:.5px;margin-bottom:4px;padding:0 8px;text-transform:uppercase}.dropdown-item{border-radius:6px;color:#333;font-size:14px;gap:8px;padding:8px 12px;transition:background .2s ease}.dropdown-item:hover{background:#f5f5f5}.item-icon{color:#666;flex-shrink:0;height:16px;width:16px}@media (max-width:768px){.form-row{grid-template-columns:1fr}.month-buttons{justify-content:flex-start}}.video-manager{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d;padding:20px}.video-title-row{margin-bottom:16px}.video-label{color:#333;font-size:14px;font-weight:500;margin:0}.main-video-container{align-items:center;display:flex;gap:20px;justify-content:center;margin-bottom:24px;position:relative}.nav-button{background:none;border:none;color:#333;cursor:pointer;flex-shrink:0;padding:8px;transition:color .2s ease}.nav-button:hover{color:#ffc107}.main-video{background:#f5f5f5;border-radius:12px;height:202px;max-width:475px;overflow:hidden;position:relative;width:100%}.main-video img{height:100%;object-fit:cover;width:100%}.video-overlay{align-items:center;background:#0000004d;display:flex;height:100%;justify-content:center;left:0;opacity:0;position:absolute;top:0;transition:opacity .3s ease;width:100%}.main-video:hover .video-overlay{opacity:1}.play-button-large{background:none;border:none;cursor:pointer;transition:transform .2s ease}.play-button-large:hover{transform:scale(1.1)}.checkbox-button{align-items:center;background:#0000004d;border:2px solid #fff;border-radius:50%;cursor:pointer;display:flex;height:32px;justify-content:center;position:absolute;right:12px;top:12px;transition:all .2s ease;width:32px}.checkbox-button:hover{background:#00000080}.checkbox-button.checked{background:#ffc107;border-color:#ffc107}.video-carousel{align-items:center;display:flex;gap:12px;margin-bottom:24px;padding:12px 0}.carousel-nav{background:none;border:none;color:#666;cursor:pointer;flex-shrink:0;padding:4px;transition:color .2s ease}.carousel-nav:hover{color:#ffc107}.thumbnails-container{flex:1 1;overflow:hidden}.thumbnails-scroll{display:flex;gap:12px;overflow-x:auto;padding:4px 0;scroll-behavior:smooth}.thumbnails-scroll::-webkit-scrollbar{height:4px}.thumbnails-scroll::-webkit-scrollbar-track{background:#f0f0f0;border-radius:2px}.thumbnails-scroll::-webkit-scrollbar-thumb{background:#ccc;border-radius:2px}.thumbnails-scroll::-webkit-scrollbar-thumb:hover{background:#999}.thumbnail-item{cursor:pointer;flex-shrink:0;position:relative;transition:transform .2s ease;width:125px}.thumbnail-item:hover{transform:translateY(-2px)}.thumbnail-item.active{border-radius:8px;box-shadow:0 4px 12px #ffc10766}.thumbnail-item img{border-radius:8px;display:block;height:53px;object-fit:cover;width:100%}.thumbnail-overlay{align-items:center;background:#0006;border-radius:8px;display:flex;height:53px;justify-content:center;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .2s ease}.thumbnail-item:hover .thumbnail-overlay{opacity:1}.thumbnail-title{color:#666;font-size:11px;margin:4px 0 0;text-align:center}.video-title-input{margin-top:20px}.title-input{border:1px solid #e0e0e0;border-radius:8px;box-sizing:border-box;font-family:inherit;font-size:14px;padding:10px 14px;transition:border-color .2s ease;width:100%}.title-input:focus{border-color:#ffc107;outline:none}.title-hint{color:#999;font-size:12px;margin:8px 0 0}@media (max-width:768px){.main-video-container{flex-direction:column;gap:12px}.main-video{height:250px;max-width:100%}.nav-button{display:none}.thumbnail-item{width:100px}.thumbnail-item img{height:45px}}.datetime-picker-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.datetime-picker{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:634px;padding:20px;position:relative;width:90%}.close-button{background:none;border:none;color:#666;cursor:pointer;padding:4px;position:absolute;right:10px;top:10px;transition:color .2s ease;z-index:10}.close-button:hover{color:#333}.picker-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr;margin:30px 0 20px}.calendar-section{padding:10px}.calendar-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.month-nav{background:none;border:none;color:#666;cursor:pointer;padding:8px;transition:color .2s ease}.month-nav:hover{color:#ffc107}.month-year{color:#333;font-size:16px;font-weight:600}.calendar-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(7,1fr)}.day-name{color:#666;font-size:12px;font-weight:500;padding:8px 4px;text-align:center}.day-name.weekend{color:#ff5252}.calendar-day{align-items:center;aspect-ratio:1;border-radius:8px;color:#333;cursor:pointer;display:flex;font-size:14px;justify-content:center;transition:all .2s ease}.calendar-day:not(.empty):hover{background:#f5f5f5}.calendar-day.empty{cursor:default}.calendar-day.today{border:2px solid #ffc107}.calendar-day.selected{background:#ffc107;color:#fff;font-weight:600}.time-section{background:#fafafa;border-radius:12px;display:flex;flex-direction:column;gap:20px;justify-content:center;padding:20px}.time-row{gap:12px}.time-inputs,.time-row{align-items:center;display:flex}.time-inputs{flex:1 1;gap:8px}.time-input{background:#fff;border:1px solid #e0e0e0;border-radius:6px;font-size:20px;font-weight:500;padding:8px;text-align:center;transition:border-color .2s ease;width:50px}.time-input:focus{border-color:#ffc107;outline:none}.time-input::-webkit-inner-spin-button,.time-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.time-separator{color:#333;font-size:20px;font-weight:600}.period-selector{display:flex;flex-direction:column;gap:4px}.period-option{background:#fff;border:1px solid #e0e0e0;border-radius:6px;color:#666;font-size:14px;font-weight:500;padding:8px 12px;text-align:center;transition:all .2s ease}.period-option.active{background:#ffc107;border-color:#ffc107;color:#1a1a1a}.picker-actions{border-top:1px solid #f0f0f0;display:flex;gap:12px;justify-content:flex-end;padding-top:20px}.btn-publish,.btn-save-update{border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 24px;transition:all .2s ease}.btn-save-update{background:#fff;border:1px solid #e0e0e0;color:#333}.btn-save-update:hover{background:#f5f5f5}.btn-publish{background:#ffc107;border:none;color:#1a1a1a}.btn-publish:hover{background:#ffb300;box-shadow:0 4px 12px #ffc1074d}@media (max-width:768px){.picker-content{grid-template-columns:1fr}.time-section{padding:15px}.time-input{font-size:18px;width:40px}.picker-actions{flex-direction:column}.btn-publish,.btn-save-update{width:100%}}.delete-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.delete-modal-content{animation:slideUp .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 8px 24px #00000026;max-width:400px;padding:32px;position:relative;text-align:center;width:90%}.modal-close-btn{background:none;border:none;color:#666;cursor:pointer;padding:4px;position:absolute;right:16px;top:16px;transition:color .2s}.modal-close-btn:hover{color:#333}.modal-icon{display:flex;justify-content:center;margin:0 auto 20px}.modal-title{color:#1a1a1a;font-size:20px;font-weight:600;margin:0 0 12px}.modal-message{color:#666;font-size:14px;line-height:1.5;margin:0 0 28px}.modal-actions{justify-content:center}.btn-modal-cancel,.btn-modal-delete{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;min-width:100px;padding:10px 28px;transition:all .2s}.btn-modal-cancel{background:#f5f5f5;color:#333}.btn-modal-cancel:hover{background:#e8e8e8}.btn-modal-delete{background:#e53e3e;color:#fff}.btn-modal-delete:hover{background:#c53030}.file-upload-container{width:100%}.drag-drop-area{background:#fff;border:2px dashed #ddd;border-radius:12px;cursor:pointer;padding:60px 40px;text-align:center;transition:all .3s ease}.drag-drop-area.drag-active{background:#fffbf0;border-color:#ffc107}.upload-icon{display:block;margin:0 auto 24px}.drag-drop-title{color:#333;font-size:18px;font-weight:500;margin:0 0 24px}.btn-select-files{background:#ffc107;border:none;border-radius:6px;color:#333;cursor:pointer;font-size:14px;font-weight:500;padding:12px 32px;transition:all .2s}.btn-select-files:hover{background:#ffb300;box-shadow:0 4px 8px #ffc1074d;transform:translateY(-1px)}.files-list{display:flex;flex-direction:column;gap:16px;margin-top:24px}.file-item{align-items:flex-start;background:#fff;border:1px solid #e5e5e5;border-radius:8px;display:flex;gap:16px;padding:16px}.file-preview{flex-shrink:0}.file-details{flex:1 1;min-width:0}.file-info-row{align-items:center;display:flex;gap:16px;margin-bottom:8px}.file-name{color:#333;flex:1 1;font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-size{color:#666;flex-shrink:0;font-size:13px}.btn-remove-file{background:none;border:none;color:#999;cursor:pointer;flex-shrink:0;padding:4px;transition:color .2s}.btn-remove-file:hover{color:#e53e3e}.file-progress-text{color:#666;flex-shrink:0;font-size:12px;font-weight:500;min-width:40px;text-align:right}.progress-bar{background:#f0f0f0}.progress-bar-fill{background:#ffc107;border-radius:4px;height:100%;transition:width .3s ease}@media (max-width:768px){.drag-drop-area{padding:40px 24px}.upload-icon{height:60px;width:60px}.drag-drop-title{font-size:16px}}.form-error-boundary{align-items:center;background:linear-gradient(135deg,#fef2f2,#fde8e8);display:flex;justify-content:center;min-height:100vh;padding:20px}.error-container{background:#fff;border-radius:12px;box-shadow:0 4px 20px #dc26261a;max-width:500px;padding:40px;text-align:center}.error-icon{background:#fee2e2;border-radius:50%;color:#dc2626;font-size:32px;font-weight:700;height:60px;margin:0 auto 20px;width:60px}.error-container h2{color:#1a1a1a;font-size:24px;font-weight:600;margin:0 0 12px}.error-message{color:#666;line-height:1.6;margin:0 0 24px}.error-details{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;font-size:12px;margin:16px 0;padding:12px;text-align:left}.error-details summary{border-radius:4px;color:#6b7280;cursor:pointer;font-weight:500;margin:-8px -8px 8px;padding:8px}.error-details summary:hover{background:#f3f4f6}.error-details pre{color:#b91c1c;font-family:Monaco,Courier New,monospace;line-height:1.4;margin:8px 0 0;max-height:200px;overflow-x:auto}.error-actions{gap:12px;justify-content:center;margin-top:24px}.btn-close,.btn-retry{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 24px;transition:all .2s}.btn-retry{background:#dc2626;color:#fff}.btn-retry:hover{background:#b91c1c;box-shadow:0 4px 12px #dc26264d}.btn-close{background:#e5e7eb;color:#374151}.btn-close:hover{background:#d1d5db}.retry-info{color:#9ca3af;font-size:12px;margin-top:16px}.form-error-display{align-items:flex-start;animation:slideDown .3s ease;border-radius:8px;display:flex;gap:12px;margin-bottom:16px;padding:16px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.form-error-display.network-error{background:#fef3c7;border:1px solid #fcd34d;color:#92400e}.form-error-display.server-error{background:#fee2e2;border:1px solid #fecaca;color:#b91c1c}.error-icon{align-items:center;display:flex;flex-shrink:0;height:24px;justify-content:center;min-width:24px;width:24px}.form-error-display.network-error .error-icon{color:#f59e0b}.form-error-display.server-error .error-icon{color:#ef4444}.error-icon svg{height:100%;width:100%}.error-content{flex:1 1}.error-title{font-size:14px;font-weight:600;margin:0 0 4px}.error-text{font-size:13px;line-height:1.4;margin:0 0 4px}.error-subtext{font-size:12px;margin:4px 0 0;opacity:.8}.error-actions{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:8px}.auto-retry-info{background:#0000000d;border-radius:4px;font-size:12px;padding:4px 8px;white-space:nowrap}.btn-error-retry{border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;min-width:100px;padding:6px 16px;transition:all .2s;white-space:nowrap}.form-error-display.network-error .btn-error-retry{background:#f59e0b;color:#fff}.form-error-display.network-error .btn-error-retry:hover:not(:disabled){background:#d97706;box-shadow:0 2px 8px #f59e0b4d}.form-error-display.server-error .btn-error-retry{background:#ef4444;color:#fff}.form-error-display.server-error .btn-error-retry:hover:not(:disabled){background:#dc2626;box-shadow:0 2px 8px #ef44444d}.btn-error-retry:disabled{cursor:not-allowed;opacity:.6}.max-retries-message{background:#0000000d;border-radius:4px;font-size:12px;font-weight:500;padding:4px 8px;white-space:nowrap}@media (max-width:640px){.form-error-display{align-items:flex-start;flex-direction:column}.error-actions{align-items:stretch;width:100%}.btn-error-retry{width:100%}.auto-retry-info,.max-retries-message{text-align:center;width:100%}}.validation-feedback{align-items:center;animation:fadeIn .2s ease;display:flex;font-size:12px;gap:6px;margin-top:4px}.validation-feedback.error{color:#dc2626}.validation-feedback.success{color:#16a34a}.feedback-icon{align-items:center;display:flex;flex-shrink:0;height:16px;justify-content:center;width:16px}.feedback-icon svg{height:100%;width:100%}.feedback-message{line-height:1.2}.course-creation-page{background:#f8f9fa;min-height:100vh;padding:30px}.course-form{background:#fff;border-radius:12px;box-shadow:0 1px 3px #00000014;max-width:560px;padding:24px}.course-form .form-group{margin-bottom:16px}.course-form .form-group label{color:#374151;display:block;font-size:14px;font-weight:600;margin-bottom:6px}.course-form .form-group input,.course-form .form-group select,.course-form .form-group textarea{border:1px solid #d1d5db;border-radius:8px;box-sizing:border-box;font-size:14px;padding:10px 12px;transition:border-color .2s,box-shadow .2s;width:100%}.course-form .form-group input:focus,.course-form .form-group select:focus,.course-form .form-group textarea:focus{border-color:#ffc107;box-shadow:0 0 0 3px #ffc1071a;outline:none}.course-form .form-group .input-error,.course-form .form-group .input-error:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.course-form .form-row{display:flex;gap:16px}.course-form .form-row .form-group{flex:1 1}.course-form .form-error{background:#fef2f2;border-radius:8px;color:#b91c1c;font-size:14px;margin-bottom:16px;padding:10px 12px}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.page-header h1{color:#1a1a1a;font-size:24px;font-weight:600;margin:0}.header-actions{align-items:center}.btn-feature,.btn-publish-header{border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:8px 20px;transition:all .2s ease}.btn-feature{background:#fff;border:1px solid #e0e0e0;color:#333}.btn-feature:hover{background:#f5f5f5}.btn-publish-header{background:#ffc107;border:none;color:#1a1a1a}.btn-publish-header:hover:not(:disabled){background:#ffb300;box-shadow:0 4px 12px #ffc1074d}.btn-publish-header:disabled{cursor:not-allowed;opacity:.6}.edit-delete-group{display:flex;gap:8px}.btn-delete-header,.btn-edit-header{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 14px;transition:all .2s ease}.btn-edit-header:hover{background:#f5f5f5;border-color:#d0d0d0}.btn-delete-header:hover{background:#fff5f5;border-color:#ffcdd2;color:#d32f2f}.creation-content{max-width:1200px}.learning-grid{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.grid-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.section-actions{display:flex;gap:8px;justify-content:flex-end;margin-bottom:20px}.btn-delete-section,.btn-edit-section{align-items:center;background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:6px 12px;transition:all .2s ease}.btn-edit-section:hover{background:#f5f5f5;border-color:#d0d0d0}.btn-delete-section:hover{background:#fff5f5;border-color:#ffcdd2;color:#d32f2f}.video-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000d;padding:20px;position:relative}.video-section-actions{display:flex;gap:8px;position:absolute;right:20px;top:20px}.section-heading{color:#1a1a1a;font-size:18px;font-weight:600;margin:0 0 20px}.btn-upload-videos{background:#fff;border:1px solid #e0e0e0;border-radius:8px;color:#333;cursor:pointer;font-size:14px;font-weight:500;margin-top:16px;padding:10px 24px;transition:all .2s ease}.btn-upload-videos:hover{background:#f5f5f5;border-color:#d0d0d0}.btn-save-continue{background:#ffc107;border:none;border-radius:8px;color:#1a1a1a;cursor:pointer;font-size:14px;font-weight:500;margin-top:20px;padding:10px 24px;transition:all .2s ease}.btn-save-continue:hover{background:#ffb300;box-shadow:0 4px 12px #ffc1074d}@media (max-width:968px){.course-creation-page{padding:20px}.page-header{align-items:flex-start;flex-direction:column;gap:16px}.header-actions{flex-wrap:wrap;width:100%}.grid-row{grid-template-columns:1fr}.btn-feature,.btn-publish-header{flex:1 1}.edit-delete-group{justify-content:stretch;width:100%}.btn-delete-header,.btn-edit-header{flex:1 1;justify-content:center}}.course-modules{margin:0 auto;max-width:1000px;padding:20px}.modules-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.modules-header h1{font-size:28px;font-weight:600;margin:0}.module-form-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px;padding:24px}.module-form-card h3{font-size:16px;font-weight:600;margin:0 0 20px}.form-group input,.form-group textarea{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a;outline:none}.modules-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden;width:100%}.modules-table thead{background-color:#f5f5f5;border-bottom:1px solid #eee}.modules-table th{color:#333;font-size:14px;font-weight:600;padding:16px;text-align:left}.modules-table td{border-bottom:1px solid #eee;font-size:14px;padding:16px}.modules-table tbody tr:hover{background-color:#fafafa}.course-modules .actions{align-items:center;display:flex;flex-wrap:nowrap;gap:6px;justify-content:flex-end}.course-modules .btn-action{align-items:center;background:var(--color-surface);border:1px solid #d0d5dd;border:1px solid var(--color-border-strong,#d0d5dd);border-radius:8px;color:var(--color-text);cursor:pointer;display:inline-flex;font-family:inherit;font-size:12.5px;font-weight:600;gap:5px;justify-content:center;min-height:32px;padding:6px 12px;transition:background-color .16s ease,border-color .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.course-modules .btn-action[title="Move down"],.course-modules .btn-action[title="Move up"]{color:var(--color-text-muted);font-size:14px;min-width:32px;padding:0;width:32px}.course-modules .btn-action[title="Move down"]:hover:not(:disabled),.course-modules .btn-action[title="Move up"]:hover:not(:disabled){background:var(--color-primary-soft);border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px)}.course-modules .btn-action:not(.btn-danger):not([title]){background:#fff7ec;border-color:#fde6c1;color:#b45309}.course-modules .btn-action:not(.btn-danger):not([title]):hover{background:#fff0d4;border-color:#fbcc83;box-shadow:0 2px 6px -2px #f59e0b40;color:#92400e;transform:translateY(-1px)}.course-modules .btn-action.btn-danger{background:var(--color-surface);border-color:#fecdca;color:#b42318}.course-modules .btn-action.btn-danger:hover{background:#fef3f2;border-color:#fda29b;box-shadow:0 2px 6px -2px #b423182e;color:#912018;transform:translateY(-1px)}.course-modules .btn-action:disabled{box-shadow:none;cursor:not-allowed;opacity:.4;transform:none}.course-modules .btn-action:active:not(:disabled){transform:translateY(0)}.lesson-count-badge{background:#eef2ff;border-radius:999px;color:#4338ca;display:inline-block;font-size:12px;font-weight:600;min-width:24px;padding:2px 10px;text-align:center}.status-badge{line-height:1.4}.status-badge.tone-success{background-color:#e8f5e9;border:1px solid #c8e6c9;color:#2e7d32}.status-badge.tone-warning{background-color:#fff3e0;border:1px solid #ffe0b2;color:#e65100}.status-badge.tone-info{background-color:#eef2ff;border:1px solid #e0e7ff;color:#4338ca}.status-badge.tone-danger{background-color:#ffebee;border:1px solid #ffcdd2;color:#c62828}.status-badge.tone-neutral{background-color:#f5f5f5;border:1px solid #e0e0e0;color:#616161}.course-lessons{background:var(--color-surface);padding:20px 22px}.lessons-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:18px}.lessons-header h1{color:var(--color-text);font-size:18px;font-weight:600;margin:0}.lesson-form-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px;padding:24px}.lesson-form-card h3{font-size:16px;font-weight:600;margin:0 0 20px}.form-row{grid-gap:16px;gap:16px}.form-group .input-error,.form-group .input-error:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-sm);color:var(--color-primary-contrast)}.lessons-table{background:var(--color-surface);border:1px solid var(--color-border);border-collapse:collapse;border-radius:var(--radius-lg);overflow:hidden;width:100%}.lessons-table thead{background-color:var(--color-surface-subtle);border-bottom:1px solid var(--color-border)}.lessons-table th{color:var(--color-text-muted);font-size:11.5px;font-weight:600;letter-spacing:.5px;padding:10px 14px;text-align:left;text-transform:uppercase}.lessons-table td{border-bottom:1px solid var(--color-border);color:var(--color-text);font-size:13.5px;padding:12px 14px}.lessons-table tbody tr:last-child td{border-bottom:0}.lessons-table tbody tr:hover{background-color:var(--color-surface-subtle)}.status-badge.uploaded{background-color:var(--color-success-soft);border-color:#abefc6;color:var(--color-success)}.status-badge.pending{background-color:var(--color-warning-soft);border-color:#fedf89;color:var(--color-warning)}.actions{align-items:center}.course-lessons .btn-action,.course-lessons-page .btn-action{align-items:center;background:var(--color-surface);border:1px solid #d0d5dd;border:1px solid var(--color-border-strong,#d0d5dd);border-radius:8px;color:var(--color-text);cursor:pointer;display:inline-flex;font-family:inherit;font-size:12.5px;font-weight:600;gap:5px;justify-content:center;min-height:32px;padding:6px 12px;transition:background-color .16s ease,border-color .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.course-lessons .btn-action:hover:not(:disabled):not(.btn-action-upload):not(.btn-danger),.course-lessons-page .btn-action:hover:not(:disabled):not(.btn-action-upload):not(.btn-danger){background:var(--color-primary-soft);border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px)}.course-lessons .btn-action:disabled,.course-lessons-page .btn-action:disabled{cursor:not-allowed;opacity:.4;transform:none}.course-lessons .btn-action:active:not(:disabled),.course-lessons-page .btn-action:active:not(:disabled){transform:translateY(0)}.course-lessons .btn-action[title="Move down"],.course-lessons .btn-action[title="Move up"],.course-lessons-page .btn-action[title="Move down"],.course-lessons-page .btn-action[title="Move up"]{color:var(--color-text-muted);font-size:14px;min-width:32px;padding:0;width:32px}.course-lessons .btn-action.btn-action-upload,.course-lessons-page .btn-action.btn-action-upload{background:#fff7ec;border-color:#fde6c1;color:#b45309}.course-lessons .btn-action.btn-action-upload:hover,.course-lessons-page .btn-action.btn-action-upload:hover{background:#fff0d4;border-color:#fbcc83;box-shadow:0 2px 6px -2px #f59e0b40;color:#92400e;transform:translateY(-1px)}.course-lessons .btn-action.btn-danger,.course-lessons-page .btn-action.btn-danger{border-color:#fecdca;color:#b42318}.course-lessons .btn-action.btn-danger:hover,.course-lessons-page .btn-action.btn-danger:hover{background:#fef3f2;border-color:#fda29b;box-shadow:0 2px 6px -2px #b423182e;color:#912018;transform:translateY(-1px)}.upload-progress-container{align-items:center;display:flex;gap:8px}.upload-progress{color:var(--color-primary);font-size:12px;font-weight:500;min-width:40px}.btn-cancel-upload{background:#fff;border:1px solid #dc2626;border-radius:4px;color:#dc2626;cursor:pointer;font-size:12px;padding:4px 10px;transition:all .2s}.btn-cancel-upload:hover{background-color:#ffebee;border-color:#b91c1c;color:#b91c1c}@media (max-width:768px){.form-row{grid-template-columns:1fr}.lessons-table{font-size:12px}.lessons-table td,.lessons-table th{padding:12px 8px}}.lessons-module-filter{background:#fff;border:1px solid #ddd;border-radius:6px;font-size:13px;min-width:180px;padding:8px 10px}.lesson-preview-overlay{align-items:center;background:#0f121cb3;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1000}.lesson-preview-content{background:#fff;border-radius:12px;box-shadow:0 20px 60px #00000059;display:flex;flex-direction:column;overflow:hidden;width:min(900px,100%)}.lesson-preview-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;padding:14px 18px}.lesson-preview-header h3{color:#222;font-size:16px;font-weight:600;margin:0}.lesson-preview-close{background:#0000;border:none;color:#555;cursor:pointer;font-size:28px;line-height:1;padding:0 6px}.lesson-preview-close:hover{color:#000}.lesson-preview-body{background:#000;padding:0}.lesson-preview-body p{color:#fff;margin:0;padding:40px;text-align:center}.lesson-number-badge{align-items:center;background:#fff7e6;border:1px solid #ffd591;border-radius:999px;color:#a76908;display:inline-flex;font-size:12px;font-weight:600;height:24px;justify-content:center;min-width:28px;padding:0 8px}.module-pill{background:#eef2ff;border-radius:999px;color:#4338ca;display:inline-block;font-size:12px;font-weight:500;padding:2px 10px}.module-empty{color:#9aa0a6;font-size:12px;font-style:italic}.cq-page{background:var(--color-surface);min-height:100%;padding:22px 24px}.cq-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:20px}.cq-title{color:var(--color-text);font-size:18px;font-weight:700;margin:0 0 4px}.cq-subtitle{align-items:center;color:var(--color-text-muted);display:flex;font-size:13px;gap:8px;margin:0}.cq-pill{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:600;letter-spacing:.02em;padding:2px 8px}.cq-pill-warn{background:#fff8e1;border:1px solid #fde68a;color:#b45309}.cq-pill-ok{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.cq-pill-sm{font-size:10.5px;padding:1px 7px}.cq-btn-primary{background:var(--color-primary);border:none;border-radius:7px;color:var(--color-primary-contrast);cursor:pointer;font-family:inherit;font-size:13.5px;font-weight:600;padding:9px 18px;transition:background .15s,box-shadow .15s;white-space:nowrap}.cq-btn-primary:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:0 2px 8px #0000001f}.cq-btn-primary:disabled{cursor:not-allowed;opacity:.55}.cq-error{background:#fef2f2;border:1px solid #fecaca;border-radius:7px;color:#b91c1c;font-size:13.5px;margin-bottom:16px;padding:12px 16px}.cq-toolbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}.cq-search-wrap{align-items:center;display:flex;flex:1 1;min-width:200px;position:relative}.cq-search-wrap>svg{color:var(--color-text-muted);left:11px;pointer-events:none;position:absolute}.cq-search{background:#fff;border:1px solid var(--color-border);border-radius:7px;color:var(--color-text);font-family:inherit;font-size:13.5px;padding:9px 34px;transition:border-color .15s,box-shadow .15s;width:100%}.cq-search:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1f;outline:none}.cq-search-clear{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:17px;line-height:1;padding:0 2px;position:absolute;right:10px}.cq-search-clear:hover,.cq-select{color:var(--color-text)}.cq-select{background:#fff;border:1px solid var(--color-border);border-radius:7px;cursor:pointer;font-family:inherit;font-size:13.5px;padding:9px 12px;transition:border-color .15s}.cq-select:focus{border-color:var(--color-primary);outline:none}.cq-empty{background:#fafafa;background:var(--color-surface-subtle,#fafafa);border:1px dashed var(--color-border);border-radius:10px;color:var(--color-text-muted);font-size:14px;padding:52px 20px;text-align:center}.cq-groups{display:flex;flex-direction:column;gap:12px}.cq-module{background:#fff;border:1px solid var(--color-border);border-radius:10px;overflow:hidden}.cq-module-hd{align-items:center;background:#f9f9f9;background:var(--color-surface-subtle,#f9f9f9);border:none;border-bottom:1px solid var(--color-border);cursor:pointer;display:flex;font-family:inherit;gap:10px;padding:13px 16px;text-align:left;transition:background .12s;width:100%}.cq-module-hd:hover{background:#f3f3f3}.cq-module-name{color:var(--color-text);flex:1 1;font-size:14px;font-weight:700}.cq-module-stats{color:var(--color-text-muted);font-size:12px}.cq-table{border-collapse:collapse;width:100%}.cq-table th{background:#fafafa;background:var(--color-surface-subtle,#fafafa);border-bottom:1px solid var(--color-border);color:var(--color-text-muted);font-size:11px;font-weight:700;letter-spacing:.05em;padding:9px 14px;text-align:left;text-transform:uppercase}.cq-td-num,.cq-th-num{text-align:center;width:44px}.cq-td-center,.cq-th-center{text-align:center;width:110px}.cq-th-actions{width:230px}.cq-table td{border-bottom:1px solid var(--color-border);color:var(--color-text);font-size:13.5px;padding:11px 14px;vertical-align:middle}.cq-table tr:last-child td{border-bottom:none}.cq-table tbody tr:hover{background:#fafafa}.cq-row-missing td{background:#fffbf0}.cq-row-missing:hover td{background:#fff8e6}.cq-td-num{color:var(--color-text-muted);font-size:12px;font-weight:600;text-align:center}.cq-lesson-title{font-weight:500}.cq-badge-qs{align-items:center;background:#eff6ff;border-radius:20px;color:#2563eb;display:inline-flex;font-size:11.5px;font-weight:600;padding:3px 9px}.cq-badge-none{color:var(--color-text-muted);font-size:13px}.cq-pass-score{color:var(--color-text);font-size:13px;font-weight:600}.cq-row-actions{align-items:center;display:flex;gap:6px}.cq-btn-ghost{align-items:center;background:#fff;border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);cursor:pointer;display:inline-flex;font-family:inherit;font-size:12.5px;font-weight:500;padding:5px 11px;text-decoration:none;transition:border-color .12s,color .12s,background .12s;white-space:nowrap}.cq-btn-ghost:hover{background:#fffbf0;background:var(--color-primary-soft,#fffbf0);border-color:var(--color-primary);color:var(--color-primary)}.cq-btn-results{border-color:#bfdbfe;color:#2563eb}.cq-btn-results:hover{background:#eff6ff;border-color:#93c5fd;color:#1d4ed8}.cq-btn-del{border-color:#fecaca;color:#dc2626;color:var(--color-danger,#dc2626)}.cq-btn-del:hover{background:#fef2f2;border-color:#fca5a5;color:#b91c1c}.cq-btn-add-quiz{background:#fffbf0;background:var(--color-primary-soft,#fffbf0);border:1.5px dashed var(--color-primary);border-radius:6px;color:var(--color-primary);cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:600;padding:5px 13px;transition:background .12s}.cq-btn-add-quiz:hover{background:#fef3c7}.cq-backdrop{animation:cq-fade-in .18s ease;background:#00000059;inset:0;position:fixed;z-index:200}@keyframes cq-fade-in{0%{opacity:0}to{opacity:1}}.cq-slideover{animation:cq-slide-in .22s cubic-bezier(.16,1,.3,1);background:#fff;box-shadow:-4px 0 32px #00000024;display:flex;flex-direction:column;height:100vh;max-width:100vw;position:fixed;right:0;top:0;width:520px;z-index:201}@keyframes cq-slide-in{0%{transform:translateX(100%)}to{transform:translateX(0)}}.cq-so-header{align-items:flex-start;border-bottom:1px solid var(--color-border);display:flex;flex-shrink:0;justify-content:space-between;padding:20px 24px 16px}.cq-so-title{color:var(--color-text);font-size:16px;font-weight:700;margin:0 0 3px}.cq-so-lesson{font-size:12.5px;margin:0}.cq-so-close,.cq-so-lesson{color:var(--color-text-muted)}.cq-so-close{align-items:center;background:none;border:none;border-radius:5px;cursor:pointer;display:flex;justify-content:center;padding:4px;transition:background .12s,color .12s}.cq-so-close:hover{background:#f3f3f3;color:var(--color-text)}.cq-so-body{display:flex;flex:1 1;flex-direction:column;gap:0;overflow-y:auto;padding:0 24px}.cq-so-section{border-bottom:1px solid var(--color-border);padding:20px 0}.cq-so-section:last-of-type{border-bottom:none}.cq-so-section-hd{align-items:center;display:flex;gap:10px;margin-bottom:14px}.cq-so-section-title{color:var(--color-text);flex:1 1;font-size:13.5px;font-weight:700;margin:0}.cq-q-count{align-items:center;background:var(--color-primary);border-radius:20px;color:var(--color-primary-contrast);display:inline-flex;font-size:11px;font-weight:700;height:22px;justify-content:center;min-width:22px;padding:0 6px}.cq-field{margin-bottom:14px}.cq-field:last-child{margin-bottom:0}.cq-field-sm{max-width:160px}.cq-label{color:var(--color-text);display:block;font-size:12.5px;font-weight:600;margin-bottom:6px}.cq-required{color:#dc2626;color:var(--color-danger,#dc2626);margin-left:1px}.cq-hint{color:var(--color-text-muted);font-weight:400;margin-left:3px}.cq-input{background:#fff;border:1px solid var(--color-border);border-radius:7px;box-sizing:border-box;color:var(--color-text);font-family:inherit;font-size:13.5px;padding:9px 12px;transition:border-color .15s,box-shadow .15s;width:100%}.cq-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1f;outline:none}.cq-textarea{resize:vertical}.cq-q-empty{color:var(--color-text-muted);font-size:13px;font-style:italic;margin:0}.cq-q-list{display:flex;flex-direction:column;gap:6px}.cq-q-item{border:1px solid var(--color-border);border-radius:7px;overflow:hidden}.cq-q-item-hd{align-items:center;background:#fafafa;border:none;cursor:pointer;display:flex;font-family:inherit;gap:10px;padding:10px 12px;text-align:left;transition:background .12s;width:100%}.cq-q-item-hd:hover{background:#f3f3f3}.cq-q-num{color:var(--color-text-muted);font-size:11px;font-weight:700;min-width:24px}.cq-q-text{color:var(--color-text);flex:1 1;font-size:13px;font-weight:500}.cq-q-correct{background:#f0fdf4;border-radius:5px;color:#16a34a;font-size:11.5px;font-weight:600;padding:2px 7px}.cq-q-detail{background:#fff;border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:5px;padding:10px 12px}.cq-q-opt{align-items:center;background:#fafafa;border-radius:5px;display:flex;font-size:13px;gap:8px;padding:6px 10px}.cq-q-opt-correct{background:#f0fdf4;color:#15803d;font-weight:600}.cq-opt-key{align-items:center;background:var(--color-border);border-radius:3px;display:flex;flex-shrink:0;font-size:11px;font-weight:700;height:18px;justify-content:center;width:18px}.cq-q-opt-correct .cq-opt-key{background:#bbf7d0;color:#15803d}.cq-opt-check{color:#16a34a;font-size:13px;margin-left:auto}.cq-btn-remove-q{align-self:flex-start;background:none;border:1px solid #fecaca;border-radius:5px;color:#dc2626;cursor:pointer;font-family:inherit;font-size:12px;margin-top:6px;padding:4px 10px;transition:background .12s}.cq-btn-remove-q:hover{background:#fef2f2}.cq-q-builder{background:#fafafa;border-bottom:none!important;border-top:1px solid var(--color-border)!important;margin:0 -24px;padding:20px 24px!important}.cq-options-hd{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.cq-options-hd .cq-label{margin:0}.cq-btn-sm{font-size:12px;padding:4px 10px}.cq-options{display:flex;flex-direction:column;gap:6px}.cq-option{align-items:center;background:#fff;border:1.5px solid var(--color-border);border-radius:7px;display:flex;gap:8px;padding:6px 10px;transition:border-color .12s}.cq-option-selected{background:#fffbf0;border-color:var(--color-primary)}.cq-opt-radio{background:none;border:none;cursor:pointer;flex-shrink:0;padding:0}.cq-opt-letter,.cq-opt-radio{align-items:center;display:flex}.cq-opt-letter{background:var(--color-border);border-radius:50%;color:var(--color-text-muted);font-size:11px;font-weight:700;height:24px;justify-content:center;transition:background .12s,color .12s;width:24px}.cq-option-selected .cq-opt-letter{background:var(--color-primary);color:var(--color-primary-contrast)}.cq-opt-input{background:#0000;border:none;color:var(--color-text);flex:1 1;font-family:inherit;font-size:13.5px;padding:0}.cq-opt-input:focus{outline:none}.cq-opt-del{background:none;border:none;color:var(--color-text-muted);cursor:pointer;font-size:16px;line-height:1;padding:0 2px;transition:color .12s}.cq-opt-del:hover{color:#dc2626;color:var(--color-danger,#dc2626)}.cq-btn-add-q{background:var(--color-primary);border:none;border-radius:7px;color:var(--color-primary-contrast);cursor:pointer;font-family:inherit;font-size:13.5px;font-weight:600;margin-top:6px;padding:9px 18px;transition:background .15s}.cq-btn-add-q:hover{background:var(--color-primary-hover)}.cq-form-error{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#b91c1c;font-size:13px;margin:8px 0;padding:10px 14px}.cq-so-footer{background:#fff;border-top:1px solid var(--color-border);display:flex;flex-shrink:0;gap:10px;justify-content:flex-end;padding:16px 24px}@media (max-width:768px){.cq-page{padding:16px}.cq-toolbar{flex-direction:column}.cq-search-wrap{min-width:0;min-width:auto}.cq-table td:nth-child(4),.cq-table th:nth-child(4){display:none}.cq-slideover{width:100vw}.cq-th-actions{width:auto}}.pagination-btn{font-family:inherit}.course-enrollments{margin:0 auto;max-width:1000px;padding:20px}.enrollments-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:30px}.enrollments-header h1{font-size:28px;font-weight:600;margin:0 0 8px}.enrollments-header p{color:#666;font-size:14px;margin:0}.add-student-form{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px;padding:24px}.add-student-form h3{font-size:16px;font-weight:600;margin:0 0 20px}.form-group input,.form-group select{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;width:100%}.form-group input:focus,.form-group select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a;outline:none}.enrollments-filters{display:flex;gap:12px;margin-bottom:24px}.search-input,.status-select{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:10px 12px}.search-input:focus,.status-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a;outline:none}.enrollments-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden;width:100%}.enrollments-table thead{background-color:#f5f5f5;border-bottom:1px solid #eee}.enrollments-table th{color:#333;font-size:14px;font-weight:600;padding:16px;text-align:left}.enrollments-table td{border-bottom:1px solid #eee;font-size:14px;padding:16px}.enrollments-table tbody tr:hover{background-color:#fafafa}.pagination{margin-top:20px}.course-exams{animation:exams-fade-in .36s cubic-bezier(.2,.8,.2,1) both;margin:0 auto;max-width:1200px;padding:28px 32px 80px}@keyframes exams-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.exams-header{align-items:flex-end;display:flex;gap:16px;justify-content:space-between;margin-bottom:16px}.exams-title{color:var(--color-text);font-size:22px;font-weight:700;letter-spacing:-.3px;margin:0}.exams-sub{color:var(--color-text-muted);font-size:13px;line-height:1.5;margin:4px 0 0;max-width:640px}.exams-stats{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));margin-bottom:22px}.exams-stat{animation:exams-fade-in .32s cubic-bezier(.2,.8,.2,1) both;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;display:flex;flex-direction:column;gap:4px;overflow:hidden;padding:14px 16px;position:relative}.exams-stat:before{background:var(--color-primary);content:"";height:3px;inset:0 0 auto 0;opacity:.7;position:absolute}.exams-stat.is-good:before{background:#1f9d6b}.exams-stat.is-warn:before{background:#b45309}.exams-stat.is-info:before{background:#3a72e0}.exams-stat-label{color:var(--color-text-muted);font-size:11px;font-weight:600;letter-spacing:.6px;text-transform:uppercase}.exams-stat-value{font-feature-settings:"tnum";color:var(--color-text);font-size:22px;font-variant-numeric:tabular-nums;font-weight:700;letter-spacing:-.4px;line-height:1.1}.exams-section{animation:exams-fade-in .38s cubic-bezier(.2,.8,.2,1) both;margin-bottom:22px}.exams-section-head{align-items:flex-end;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.exams-section-head h3{align-items:center;color:var(--color-text);display:inline-flex;font-size:15px;font-weight:700;gap:8px;letter-spacing:-.1px;margin:0}.exams-section-head h3 svg{color:var(--color-primary)}.exams-section-head p{color:var(--color-text-muted);font-size:12.5px;line-height:1.5;margin:4px 0 0}.exams-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.exam-card{animation:exams-fade-in .36s cubic-bezier(.2,.8,.2,1) both;background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;display:flex;flex-direction:column;gap:14px;padding:18px 20px 14px;transition:transform .24s cubic-bezier(.2,.8,.2,1),box-shadow .24s ease,border-color .24s ease}.exam-card:hover{border-color:var(--color-border-strong);box-shadow:0 12px 28px -10px #0f172a2e;transform:translateY(-2px)}.exam-card.is-final{background:linear-gradient(180deg,#fff7ec 0,var(--color-surface) 60%);border-color:#fde6c1;box-shadow:0 1px 2px #f59e0b14}.exam-card.is-final:hover{box-shadow:0 12px 28px -10px #f59e0b52}.exam-card-head{align-items:flex-start;display:flex;gap:12px}.exam-card-icon{align-items:center;background:var(--color-primary-soft);border-radius:10px;color:var(--color-primary);display:inline-flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.exam-card.is-final .exam-card-icon{background:#fde6c1;color:#92400e}.exam-card-title-block{flex:1 1;min-width:0}.exam-card-meta-row{align-items:center;display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.exam-card-title{color:var(--color-text);font-size:15px;font-weight:700;letter-spacing:-.1px;line-height:1.3;margin:2px 0 4px;word-break:break-word}.exam-card-desc{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--color-text-muted);display:-webkit-box;font-size:12.5px;line-height:1.5;margin:0;overflow:hidden}.exam-status{align-items:center;border-radius:999px;display:inline-flex;font-size:11px;font-weight:600;gap:5px;letter-spacing:.2px;padding:3px 10px 3px 8px}.exam-status-dot{animation:exams-pulse 2.2s ease-in-out infinite;background:currentColor;border-radius:50%;height:6px;width:6px}@keyframes exams-pulse{0%,to{opacity:.85}50%{opacity:1}}.exam-status.is-published{background:#ebfaf1;border:1px solid #abefc6;color:#0e7c4a}.exam-status.is-draft{background:#fff7ec;border:1px solid #fde6c1;color:#92400e}.exam-status.is-archived{background:#f3f4f6;border:1px solid #e5e7eb;color:#4b5563}.exam-final-pill{align-items:center;background:linear-gradient(135deg,#fde6c1,#fff0d4);border:1px solid #fbcc83;border-radius:999px;color:#92400e;display:inline-flex;font-size:11px;font-weight:700;gap:4px;padding:3px 10px 3px 8px}.exam-final-pill svg{color:#f59e0b}.exam-module-pill{align-items:center;border:1px solid var(--color-border);border-radius:999px;color:var(--color-text-muted);display:inline-flex;font-size:11px;font-weight:600;max-width:220px;overflow:hidden;padding:3px 10px;text-overflow:ellipsis;white-space:nowrap}.exam-card-stats,.exam-module-pill{background:var(--color-surface-subtle)}.exam-card-stats{border-radius:10px;display:flex;gap:18px;padding:12px 14px}.exam-card-stat{align-items:center;color:var(--color-text-muted);display:flex;font-size:12.5px;gap:6px}.exam-card-stat-icon{color:var(--color-text-subtle);display:inline-flex}.exam-card-stat-value{font-feature-settings:"tnum";color:var(--color-text);font-size:14px;font-variant-numeric:tabular-nums;font-weight:700}.exam-card-stat-label{font-size:11.5px}.exam-card-actions{display:flex;gap:8px;margin-top:auto}.exam-btn{align-items:center;border:1px solid #0000;border-radius:9px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:12.5px;font-weight:600;gap:5px;justify-content:center;padding:8px 14px;transition:background-color .18s ease,border-color .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease;white-space:nowrap}.exam-btn:active:not(:disabled){transform:translateY(1px)}.exam-btn:disabled{cursor:not-allowed;opacity:.55}.exam-btn.is-publish{background:var(--color-primary);border-color:var(--color-primary);box-shadow:0 2px 6px -2px #f59e0b66;color:var(--color-primary-contrast)}.exam-btn.is-publish:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:0 6px 14px -4px #f59e0b80;transform:translateY(-1px)}.exam-btn.is-archive{background:var(--color-surface);border-color:var(--color-border-strong);color:var(--color-text-muted)}.exam-btn.is-archive:hover{background:var(--color-surface-subtle);border-color:#b8bcc6;color:var(--color-text)}.exam-btn.is-edit{background:#fff7ec;border-color:#fde6c1;color:#b45309}.exam-btn.is-edit:hover{background:#fff0d4;border-color:#fbcc83;transform:translateY(-1px)}.exam-btn.is-delete{background:var(--color-surface);border-color:#fecdca;color:#b42318}.exam-btn.is-delete:hover{background:#fef3f2;border-color:#fda29b;transform:translateY(-1px)}.exam-btn.is-cancel{background:var(--color-surface);border-color:var(--color-border-strong);color:var(--color-text);padding:9px 18px}.exam-btn.is-cancel:hover{background:var(--color-surface-subtle)}.exam-btn.is-primary{background:var(--color-primary);border-color:var(--color-primary);box-shadow:0 2px 6px -2px #f59e0b66;color:var(--color-primary-contrast);padding:9px 18px}.exam-btn.is-primary:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:0 6px 14px -4px #f59e0b80;transform:translateY(-1px)}.exam-card-empty{align-items:center;background:#0000;border:1.5px dashed var(--color-border-strong);border-radius:14px;color:var(--color-text-muted);cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:8px;justify-content:center;min-height:220px;padding:28px 18px;text-align:center;transition:background-color .18s ease,border-color .18s ease,color .18s ease,transform .18s ease}.exam-card-empty:hover{border-color:var(--color-primary);transform:translateY(-2px)}.exam-card-empty-icon,.exam-card-empty:hover{background:var(--color-primary-soft);color:var(--color-primary)}.exam-card-empty-icon{align-items:center;border-radius:10px;display:inline-flex;height:36px;justify-content:center;width:36px}.exam-card-empty:hover .exam-card-empty-icon{background:var(--color-primary);color:var(--color-primary-contrast)}.exam-card-empty-title{color:var(--color-text);font-size:13.5px;font-weight:600;margin-top:4px}.exam-card-empty-sub{color:var(--color-text-muted);font-size:12px}.exam-form-overlay{align-items:center;animation:exam-form-fade-in .2s ease both;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);background:#0f172a6b;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:60}@keyframes exam-form-fade-in{0%{opacity:0}to{opacity:1}}.exam-form{animation:exam-form-pop-in .28s cubic-bezier(.2,.8,.2,1) both;background:var(--color-surface);border-radius:16px;box-shadow:0 24px 64px -12px #0f172a73;display:flex;flex-direction:column;max-height:calc(100vh - 48px);max-width:720px;overflow:hidden;width:100%}@keyframes exam-form-pop-in{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.exam-form-head{align-items:flex-start;border-bottom:1px solid var(--color-border);display:flex;gap:16px;justify-content:space-between;padding:20px 24px}.exam-form-head h3{color:var(--color-text);font-size:17px;font-weight:700;letter-spacing:-.2px;margin:0 0 4px}.exam-form-head p{color:var(--color-text-muted);font-size:12.5px;margin:0}.exam-form-close{align-items:center;background:#0000;border:0;border-radius:8px;color:var(--color-text-muted);cursor:pointer;display:inline-flex;justify-content:center;padding:6px;transition:background-color .16s ease,color .16s ease}.exam-form-close:hover{background:var(--color-surface-subtle);color:var(--color-text)}.exam-form-body{gap:18px;overflow-y:auto;padding:20px 24px}.exam-form-body,.exam-form-row{display:flex;flex-direction:column}.exam-form-row{gap:6px}.exam-form-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr))}.exam-form-label{color:var(--color-text);font-size:12.5px;font-weight:600;letter-spacing:.1px}.exam-form-label em{color:#b42318;font-style:normal;margin-left:2px}.exam-scope-pills{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr))}.exam-scope-pill{align-items:flex-start;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:2px;padding:12px 14px;text-align:left;transition:border-color .18s ease,background-color .18s ease,transform .18s ease,box-shadow .18s ease}.exam-scope-pill:hover{border-color:var(--color-border-strong);transform:translateY(-1px)}.exam-scope-pill.is-active{background:#fff7ec;border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b29}.exam-scope-icon{align-items:center;background:var(--color-primary-soft);border-radius:8px;color:var(--color-primary);display:inline-flex;height:30px;justify-content:center;margin-bottom:4px;width:30px}.exam-scope-label{color:var(--color-text);font-size:13px;font-weight:700}.exam-scope-pill.is-active .exam-scope-label{color:#92400e}.exam-scope-sub{color:var(--color-text-muted);font-size:11.5px}.exam-toggles{background:var(--color-surface-subtle);border-radius:12px;display:flex;flex-direction:column;gap:10px;padding:12px 14px}.exam-toggle-row{align-items:center;border-bottom:1px dashed var(--color-border);display:flex;gap:12px;justify-content:space-between;padding:8px 4px}.exam-toggle-row:last-child{border-bottom:none}.exam-toggle-row strong{color:var(--color-text);display:block;font-size:13px;font-weight:600}.exam-toggle-row span{color:var(--color-text-muted);display:block;font-size:11.5px;margin-top:2px}.exam-form-foot{background:var(--color-surface-subtle);border-top:1px solid var(--color-border);display:flex;gap:10px;justify-content:flex-end;padding:14px 24px}@media (max-width:720px){.exam-form-grid,.exam-scope-pills{grid-template-columns:1fr}.exam-card-stats{flex-wrap:wrap;gap:12px}.exam-card-actions{flex-wrap:wrap}.exam-card-actions .exam-btn{flex-basis:calc(50% - 4px);flex-grow:1;flex-shrink:1}}@media (prefers-reduced-motion:reduce){.course-exams,.exam-card,.exam-form,.exam-form-overlay,.exam-status-dot,.exams-section,.exams-stat{animation:none!important;transition:none!important}.exam-card:hover{transform:none}}.course-overview{background:var(--color-bg);min-height:100vh;padding:24px 28px}.btn-link{align-items:center;background:none;border:0;border-radius:6px;color:var(--color-text-muted);cursor:pointer;display:inline-flex;font-family:inherit;font-size:13px;gap:4px;margin-bottom:14px;padding:4px 8px 4px 0;transition:color .16s ease,transform .16s ease}.btn-link:hover{color:var(--color-primary);transform:translateX(-2px)}.overview-header{align-items:flex-end;animation:ov-fade-in .36s cubic-bezier(.2,.8,.2,1) both;background:linear-gradient(135deg,#f59e0b1a 0,#f59e0b05 60%,#0000 100%),var(--color-surface);border:1px solid var(--color-border);border-radius:16px;display:flex;gap:24px;justify-content:space-between;margin-bottom:22px;overflow:hidden;padding:28px 28px 24px;position:relative}.overview-header:before{background:radial-gradient(closest-side,#f59e0b2e,#0000 70%);content:"";height:220px;pointer-events:none;position:absolute;right:-60px;top:-60px;width:220px}@keyframes ov-fade-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.overview-title{color:var(--color-text);font-size:26px;font-weight:700;letter-spacing:-.4px;line-height:1.2;margin:0 0 8px}.overview-subline{align-items:center;color:var(--color-text-muted);display:flex;flex-wrap:wrap;font-size:13px;gap:10px}.chip-sep{opacity:.4}.status-chip{align-items:center;border:1px solid #0000;border-radius:999px;display:inline-flex;font-size:11.5px;font-weight:600;gap:6px;letter-spacing:.2px;padding:4px 12px 4px 10px}.status-chip:before{animation:ov-pulse 2.2s ease-in-out infinite;background:currentColor;border-radius:50%;content:"";height:7px;width:7px}@keyframes ov-pulse{0%,to{opacity:.85}50%{opacity:1}}.status-chip.live{background:var(--color-success-soft);border-color:#abefc6;color:var(--color-success)}.status-chip.draft{background:var(--color-warning-soft);border-color:#fedf89;color:var(--color-warning)}.owner-chip{align-items:center;background:var(--color-success-soft);border:1px solid #abefc6;border-radius:999px;color:var(--color-success);display:inline-flex;font-weight:600;gap:4px;padding:2px 10px}.overview-actions{display:flex;gap:10px;position:relative;z-index:1}.btn-cancel,.btn-danger,.btn-primary,.btn-secondary{border:1px solid #0000;border-radius:10px;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;padding:10px 18px;transition:background-color .18s ease,border-color .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease}.btn-primary{border-color:var(--color-primary);box-shadow:0 2px 6px -2px #f59e0b66;color:var(--color-primary-contrast)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover);box-shadow:0 6px 16px -4px #f59e0b80;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.55}.btn-secondary{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-subtle);border-color:var(--color-border-strong);transform:translateY(-1px)}.btn-danger{background:var(--color-surface);border-color:#fecdca;color:var(--color-danger)}.btn-danger:hover{background:var(--color-danger-soft);border-color:#fda29b;box-shadow:0 2px 6px -2px #b4231840;color:#912018;transform:translateY(-1px)}.btn-cancel{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text)}.btn-cancel:hover{background:var(--color-surface-subtle);border-color:var(--color-border-strong)}.overview-stats{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:22px}.stat-card{align-items:center;animation:ov-stat-in .32s cubic-bezier(.2,.8,.2,1) both;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 1px 2px #0f172a0a;display:flex;gap:14px;padding:18px 20px;transition:transform .22s cubic-bezier(.2,.8,.2,1),box-shadow .22s ease}.stat-card:first-child{animation-delay:0ms}.stat-card:nth-child(2){animation-delay:60ms}.stat-card:nth-child(3){animation-delay:.12s}.stat-card:hover{box-shadow:0 8px 20px -10px #0f172a2e;transform:translateY(-2px)}.stat-card:before{background:var(--color-primary-soft);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23b45309' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M2 3h6a4 4 0 0 1 4 4v14a3 3 0 0 0-3-3H2zM22 3h-6a4 4 0 0 0-4 4v14a3 3 0 0 1 3-3h7z'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:22px 22px;border-radius:12px;content:"";flex-shrink:0;height:42px;width:42px}.stat-card:nth-child(2):before{background-color:#ebfaf1;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231f9d6b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m9 11 3 3L22 4'/%3E%3Cpath d='M21 12v7a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V5a2 2 0 0 1 2-2h11'/%3E%3C/svg%3E")}.stat-card:nth-child(3):before{background-color:#eaf3ff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233a72e0' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='10'/%3E%3Cpath d='m9 12 2 2 4-4'/%3E%3C/svg%3E")}@keyframes ov-stat-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.stat-label{color:var(--color-text-muted);font-weight:600;letter-spacing:.6px;text-transform:uppercase}.stat-value{font-feature-settings:"tnum";color:var(--color-text);font-size:24px;font-variant-numeric:tabular-nums;letter-spacing:-.4px;line-height:1.1;margin-top:4px}.overview-tabs{background:var(--color-surface);border:1px solid var(--color-border);border-bottom:0;border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;gap:4px;margin-bottom:0;overflow-x:auto;padding:6px 12px 0;position:relative;scrollbar-width:none}.overview-tabs::-webkit-scrollbar{display:none}.tab{background:#0000;border:0;border-bottom:2px solid #0000;color:var(--color-text-muted);cursor:pointer;font-family:inherit;font-size:13.5px;font-weight:500;margin-bottom:-1px;padding:12px 16px;position:relative;transition:color .18s ease;white-space:nowrap}.tab:after{background:var(--color-primary);border-radius:2px 2px 0 0;bottom:-1px;content:"";height:2px;left:50%;position:absolute;transform:translateX(-50%);transition:width .22s cubic-bezier(.2,.8,.2,1);width:0}.tab:hover{color:var(--color-text)}.tab:hover:after{background:var(--color-text-muted);opacity:.4;width:40%}.tab-active{color:var(--color-primary);font-weight:600}.tab-active:after{background:var(--color-primary);opacity:1;width:calc(100% - 24px)}.overview-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:0 0 var(--radius-lg) var(--radius-lg);border-top:0;box-shadow:var(--shadow-xs);padding:0}.overview-panel .course-enrollments,.overview-panel .course-lessons,.overview-panel .course-modules,.overview-panel .course-quizzes{margin:0;max-width:none}.overview-panel .course-lessons-page,.overview-panel .course-quizzes-page,.overview-panel .student-progress-page{background:#fff!important;min-height:auto!important;padding:20px!important}.students-tab{padding:20px 24px}.students-tab-toolbar{margin-bottom:16px}.students-tab-toolbar input{border:1px solid #d5d5d5;border-radius:8px;font-size:14px;max-width:320px;outline:none;padding:10px 12px;width:100%}.students-tab-toolbar input:focus{border-color:#fbbf24}.students-tab-empty{color:#6b7280;padding:24px 0;text-align:center}.students-tab-table{border-collapse:collapse;width:100%}.students-tab-table td,.students-tab-table th{border-bottom:1px solid #f0f0f0;font-size:14px;padding:12px 8px;text-align:left}.students-tab-table th{background:#fafafa;color:#6b7280;font-weight:600}.settings-panel{margin:0 auto;max-width:920px;padding:28px 32px 120px;position:relative}.settings-section{animation:settings-in .36s cubic-bezier(.2,.8,.2,1) both;background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;margin-bottom:16px;padding:22px 24px}.settings-section:first-child{animation-delay:0ms}.settings-section:nth-child(2){animation-delay:60ms}.settings-section:nth-child(3){animation-delay:.12s}.settings-section:nth-child(4){animation-delay:.18s}@keyframes settings-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.settings-section-head{align-items:flex-start;display:flex;gap:16px;justify-content:space-between;margin-bottom:18px}.settings-section-title{color:var(--color-text);font-size:15px;font-weight:700;letter-spacing:-.1px;margin:0}.settings-section-sub{color:var(--color-text-muted);font-size:12.5px;line-height:1.5;margin:4px 0 0}.settings-grid{grid-gap:18px;display:grid;gap:18px;grid-template-columns:repeat(2,minmax(0,1fr))}.settings-field{display:flex;flex-direction:column;gap:6px}.settings-field-full{grid-column:1/-1}.settings-field>span:first-child,.settings-label,.settings-label-row>span:first-child{color:var(--color-text);font-size:12.5px;font-weight:600;letter-spacing:.1px}.settings-label-row{align-items:baseline;display:flex;gap:8px;justify-content:space-between}.settings-label-row em{color:#b42318;font-style:normal;margin-left:2px}.settings-counter{font-feature-settings:"tnum";color:var(--color-text-subtle);font-size:11px;font-variant-numeric:tabular-nums;font-weight:500}.settings-counter.is-over{color:#b42318;font-weight:600}.settings-help{color:var(--color-text-muted);font-size:11.5px;line-height:1.5}.settings-help.is-error{color:#b42318}.settings-field input,.settings-field select,.settings-field textarea{background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:10px;color:var(--color-text);font-family:inherit;font-size:14px;outline:none;padding:10px 12px;transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease}.settings-field input:hover:not(:disabled),.settings-field select:hover:not(:disabled),.settings-field textarea:hover:not(:disabled){border-color:#b8bcc6}.settings-field input:focus,.settings-field select:focus,.settings-field textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b2e}.settings-field input[aria-invalid=true]{background:snow;border-color:#fda29b}.settings-field textarea{line-height:1.5;min-height:100px;resize:vertical}.settings-pills{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,minmax(0,1fr))}.settings-pill{align-items:flex-start;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:4px;padding:12px 14px;text-align:left;transition:border-color .18s ease,background-color .18s ease,transform .18s ease,box-shadow .18s ease}.settings-pill:hover{border-color:var(--color-border-strong);box-shadow:0 4px 12px -6px #0f172a1f;transform:translateY(-1px)}.settings-pill.is-active{background:#fff7ec;border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b29}.settings-pill-label{color:var(--color-text);font-size:13.5px;font-weight:600}.settings-pill.is-active .settings-pill-label{color:#92400e}.settings-pill-sub{color:var(--color-text-muted);font-size:11.5px;line-height:1.4}.settings-price-input{align-items:stretch;background:var(--color-surface);border:1px solid var(--color-border-strong);border-radius:10px;display:flex;overflow:hidden;transition:border-color .18s ease,box-shadow .18s ease}.settings-price-input:hover:not(.is-disabled){border-color:#b8bcc6}.settings-price-input:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b2e}.settings-price-input.is-disabled{background:#f8f9fb;opacity:.7}.settings-price-input input{font-feature-settings:"tnum";background:#0000;border:0!important;box-shadow:none!important;flex:1 1;font-size:14px;font-variant-numeric:tabular-nums;outline:none!important;padding:10px 12px}.settings-price-suffix{background:var(--color-surface-subtle);border-left:1px solid var(--color-border);font-size:12px;font-weight:700;letter-spacing:.5px;padding:0 14px}.settings-price-suffix,.settings-switch{align-items:center;color:var(--color-text-muted);display:inline-flex}.settings-switch{background:#0000;border:0;cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;gap:10px;padding:0;width:fit-content}.settings-switch-track{background:#d1d5db;border-radius:999px;flex-shrink:0;height:22px;position:relative;transition:background .22s ease;width:40px}.settings-switch-thumb{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;height:18px;left:2px;position:absolute;top:2px;transition:transform .24s cubic-bezier(.2,.8,.2,1);width:18px}.settings-switch.is-on .settings-switch-track{background:var(--color-primary)}.settings-switch.is-on .settings-switch-thumb{transform:translateX(18px)}.settings-switch.is-on{color:var(--color-primary)}.settings-banner{align-items:center;animation:settings-banner-in .24s ease both;border:1px solid #0000;border-radius:10px;display:flex;font-size:13px;font-weight:500;gap:8px;margin:0 0 16px;padding:12px 14px}.settings-banner.is-error{background:#fef3f2;border-color:#fecdca;color:#912018}.settings-banner.is-ok{background:#ebfaf1;border-color:#abefc6;color:#0e7c4a}@keyframes settings-banner-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.overview-error,.settings-error,.settings-ok{background:#fff5f5;border-radius:8px;color:#c53030;font-size:14px;margin-top:12px;padding:10px 12px}.settings-ok{background:#e6f7ee;color:#068e52}.settings-actions{gap:12px;margin-top:20px}.settings-actions,.settings-savebar{display:flex;justify-content:space-between}.settings-savebar{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#fffffff5;border:1px solid var(--color-border);border-radius:14px;bottom:16px;box-shadow:0 12px 28px -10px #0f172a2e,0 4px 8px -4px #0f172a0f;gap:16px;margin:8px 0 16px;opacity:0;padding:12px 18px;pointer-events:none;position:sticky;transform:translateY(8px);transition:opacity .22s ease,transform .22s cubic-bezier(.2,.8,.2,1);z-index:5}.settings-savebar.is-visible{opacity:1;pointer-events:auto;transform:translateY(0)}.settings-savebar-text{align-items:center;color:var(--color-text);display:flex;font-size:13px;font-weight:600;gap:8px}.settings-savebar-text:before{animation:settings-savebar-pulse 1.8s ease-in-out infinite;background:var(--color-primary);border-radius:50%;box-shadow:0 0 0 0 #f59e0b80;content:"";height:8px;width:8px}@keyframes settings-savebar-pulse{0%,to{box-shadow:0 0 0 0 #f59e0b80}50%{box-shadow:0 0 0 6px #0000}}.settings-savebar-actions{display:flex;gap:8px}.settings-savebar-actions .btn-cancel,.settings-savebar-actions .btn-primary{font-size:12.5px;padding:8px 16px}.settings-danger{background:linear-gradient(180deg,snow 0,var(--color-surface) 60%);border-color:#fecdca}.settings-danger .settings-section-title{color:#912018}.settings-danger-row{align-items:center;background:#fff;border:1px solid #fecdca;border-radius:12px;display:flex;gap:16px;justify-content:space-between;padding:14px 16px}.settings-danger-info{display:flex;flex-direction:column;gap:2px}.settings-danger-info strong{color:var(--color-text);font-size:13.5px;font-weight:600}.settings-danger-info span{color:var(--color-text-muted);font-size:12.5px;line-height:1.5}@media (max-width:720px){.settings-panel{padding:18px 16px 120px}.settings-grid,.settings-pills{grid-template-columns:1fr}.settings-danger-row,.settings-savebar{align-items:stretch;flex-direction:column}.settings-savebar{gap:8px}.settings-savebar-actions{flex-direction:row}.settings-savebar-actions .btn-cancel,.settings-savebar-actions .btn-primary{flex:1 1}}@media (prefers-reduced-motion:reduce){.settings-banner,.settings-savebar,.settings-savebar-text:before,.settings-section{animation:none!important;transition:none!important}}.modal-overlay{background:#00000073;z-index:50}.modal-content{max-width:calc(100% - 32px);overflow:hidden;width:420px}.modal-header{border-bottom:1px solid #ececec;padding:16px 20px}.modal-body{color:#1a1a1a;padding:16px 20px}.modal-actions{border-top:1px solid #ececec;gap:8px;padding:12px 20px}.auth-page{max-height:100vh}.auth-left,.auth-page{display:flex;height:100vh;overflow:hidden}.auth-left{background:linear-gradient(160deg,#1a1208,#271a0a 45%,#6b2d00);flex-direction:column;flex-shrink:0;gap:28px;justify-content:center;padding:36px 48px;position:relative;width:44%}.auth-left:before{background:radial-gradient(circle,#f59e0b38 0,#0000 68%);height:380px;right:-100px;top:-80px;width:380px}.auth-left:after,.auth-left:before{border-radius:50%;content:"";pointer-events:none;position:absolute}.auth-left:after{background:radial-gradient(circle,#f59e0b1f 0,#0000 68%);bottom:-60px;height:280px;left:-60px;width:280px}.auth-left-pattern{background-image:radial-gradient(#ffffff0a 1px,#0000 0);background-size:28px 28px;inset:0;pointer-events:none;position:absolute}.auth-brand{position:relative;z-index:1}.auth-logo{gap:10px;margin-bottom:28px}.auth-logo,.auth-logo-mark{align-items:center;display:flex}.auth-logo-mark{background:#f59e0b;border-radius:10px;box-shadow:0 4px 14px #f59e0b66;color:#1a1a1a;flex-shrink:0;font-size:19px;font-weight:900;height:38px;justify-content:center;letter-spacing:-1px;width:38px}.auth-logo-name{color:#ffffffe6;font-size:20px;font-weight:700;letter-spacing:-.2px}.auth-logo-name span{color:#f59e0b}.auth-tagline{color:#fff;font-size:25px;font-weight:700;letter-spacing:-.5px;line-height:1.3;margin:0 0 10px}.auth-tagline em{color:#f59e0b;font-style:normal}.auth-desc{color:#ffffff85;font-size:13.5px;line-height:1.6;margin:0 0 20px;max-width:340px}.auth-features{display:flex;flex-direction:column;gap:8px}.auth-feature{align-items:center;background:#ffffff0a;border:1px solid #ffffff12;border-radius:10px;display:flex;gap:12px;padding:10px 12px;transition:background .2s}.auth-feature:hover{background:#f59e0b14;border-color:#f59e0b2e}.auth-feature-icon{align-items:center;background:#f59e0b24;border-radius:8px;color:#f59e0b;display:flex;flex-shrink:0;height:34px;justify-content:center;width:34px}.auth-feature-text strong{color:#ffffffe0;display:block;font-size:13px;font-weight:600;margin-bottom:1px}.auth-feature-text span{color:#ffffff6b;font-size:12px;line-height:1.4}.auth-stats{background:#ffffff0d;border:1px solid #ffffff17;border-radius:14px;display:flex;gap:0;overflow:hidden;position:relative;z-index:1}.auth-stat{border-right:1px solid #ffffff17;flex:1 1;padding:16px 20px;text-align:center}.auth-stat:last-child{border-right:none}.auth-stat strong{color:#f59e0b;display:block;font-size:20px;font-weight:700;letter-spacing:-.5px}.auth-stat span{color:#ffffff6b;display:block;font-size:11px;margin-top:2px;white-space:nowrap}.auth-right{align-items:center;background:#f6f5f2;display:flex;flex:1 1;height:100vh;justify-content:center;overflow:hidden;padding:32px;position:relative}.auth-right:before{background:radial-gradient(circle,#f59e0b0f 0,#0000 65%);height:360px;right:-120px;top:-120px;width:360px}.auth-right:after,.auth-right:before{border-radius:50%;content:"";pointer-events:none;position:absolute}.auth-right:after{background:radial-gradient(circle,#f59e0b0d 0,#0000 65%);bottom:-80px;height:280px;left:-80px;width:280px}.auth-form-wrap{max-width:400px;position:relative;width:100%;z-index:1}.auth-card{background:#fff;border:1px solid #0000000f;border-radius:20px;box-shadow:0 2px 4px #0000000a,0 8px 32px #00000014;padding:36px 36px 32px}.auth-form-header{margin-bottom:28px}.auth-form-header h1{color:#111;font-size:22px;font-weight:700;letter-spacing:-.4px;margin:0 0 5px}.auth-form-header p{color:#999;font-size:13.5px;margin:0}.auth-field{margin-bottom:16px}.auth-field label{color:#444;display:block;font-size:12.5px;font-weight:600;letter-spacing:.4px;margin-bottom:6px;text-transform:uppercase}.auth-field input{background:#fafafa;border:1.5px solid #e8e8e8;border-radius:10px;box-sizing:border-box;color:#111;font-family:inherit;font-size:14px;outline:none;padding:11px 14px;transition:border-color .15s,box-shadow .15s,background .15s;width:100%}.auth-field input:focus{background:#fff;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.auth-field-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.auth-field-row label{color:#444;font-size:12.5px;font-weight:600;letter-spacing:.4px;margin:0;text-transform:uppercase}.auth-forgot-link{color:#f59e0b;font-size:12px;font-weight:500;text-decoration:none}.auth-forgot-link:hover{text-decoration:underline}.auth-error{align-items:flex-start;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;display:flex;gap:8px}.auth-error,.auth-success{font-size:13px;margin-bottom:14px;padding:10px 12px}.auth-success{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;color:#16a34a}.auth-submit{background:#f59e0b;border:none;border-radius:10px;box-shadow:0 2px 10px #f59e0b40;color:#1a1a1a;cursor:pointer;font-size:14.5px;font-weight:700;letter-spacing:-.1px;margin-top:6px;padding:12px 16px;transition:background-color .15s,box-shadow .15s,transform .1s;width:100%}.auth-submit:hover:not(:disabled){background:#e08e00;box-shadow:0 4px 18px #f59e0b61}.auth-submit:active:not(:disabled){box-shadow:0 1px 6px #f59e0b33;transform:scale(.99)}.auth-submit:disabled{cursor:not-allowed;opacity:.6}.auth-switch{color:#999;font-size:13px;margin-top:18px;text-align:center}.auth-switch a{color:#f59e0b;font-weight:600;text-decoration:none}.auth-switch a:hover{text-decoration:underline}.auth-back-link{align-items:center;color:#aaa;display:inline-flex;font-size:13px;gap:6px;margin-bottom:20px;text-decoration:none;transition:color .12s}.auth-back-link:hover{color:#555}.auth-info-box{background:#fffbeb;border:1px solid #fde68a;border-radius:10px;color:#92400e;font-size:12.5px;line-height:1.55;margin-bottom:20px;padding:12px 14px}@media (max-width:800px){.auth-page{flex-direction:column}.auth-left{min-height:auto;padding:32px 28px;width:100%}.auth-tagline{font-size:22px}.auth-features{display:none}.auth-right{padding:32px 20px}.auth-card{padding:28px 22px}}.searchable-course-select{position:relative;width:100%}.select-button{align-items:center;background:#fff;border:1px solid #ddd;border-radius:4px;cursor:pointer;display:flex;font-size:14px;justify-content:space-between;padding:10px 12px;text-align:left;transition:border-color .2s;width:100%}.select-button:hover:not(:disabled){border-color:#999}.select-button:disabled{cursor:not-allowed;opacity:.5}.select-button svg{flex-shrink:0;margin-left:auto}.select-dropdown{background:#fff;border:1px solid #ddd;border-radius:4px;box-shadow:0 2px 8px #0000001a;display:flex;flex-direction:column;left:0;margin-top:4px;max-height:400px;position:absolute;right:0;top:100%;z-index:1000}.select-search{border-bottom:1px solid #eee;padding:8px}.search-input{border-radius:4px;padding:8px}.search-input:focus{border-color:#4a90e2;box-shadow:0 0 0 2px #4a90e21a}.select-list{flex:1 1;list-style:none;margin:0;overflow-y:auto;padding:0}.select-item{align-items:center;background:#fff;border:none;border-bottom:1px solid #f5f5f5;cursor:pointer;display:flex;font-size:14px;justify-content:space-between;padding:10px 12px;text-align:left;transition:background-color .2s;width:100%}.select-item:hover{background-color:#f5f5f5}.select-item.selected{background-color:#e8f0fe;color:#4a90e2;font-weight:500}.course-title{flex:1 1}.course-level{background:#f5f5f5;border-radius:2px;color:#999;font-size:12px;margin-left:8px;padding:2px 6px}.select-empty{color:#999;font-size:14px;padding:16px;text-align:center}.select-error{background-color:#fee;border-bottom:1px solid #fdd;color:#c33;font-size:13px;padding:12px}.select-loading{color:#999;font-size:13px;padding:12px;text-align:center}.select-load-more{background:#fff;border:none;border-top:1px solid #eee;color:#4a90e2;cursor:pointer;font-size:13px;font-weight:500;padding:10px;transition:background-color .2s}.select-load-more:hover{background-color:#f5f5f5}.students-page{background-color:var(--color-bg);min-height:100%;padding:24px 28px}.students-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:20px}.students-header h1{color:var(--color-text);font-size:22px;font-weight:700;letter-spacing:-.2px;margin:0}.students-controls{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.course-select{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:inherit;font-size:13.5px;min-width:220px;outline:none;padding:9px 12px}.course-select:hover{border-color:var(--color-border-strong)}.search-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:inherit;font-size:13.5px;outline:none;padding:9px 12px;width:240px}.search-input:hover{border-color:var(--color-border-strong)}.students-error{background:var(--color-danger-soft);border:1px solid #fecdca;border-radius:var(--radius-md);color:var(--color-danger);font-size:13.5px;margin-bottom:16px;padding:10px 14px}.students-hint{background:var(--color-surface);border:1px dashed var(--color-border-strong);border-radius:var(--radius-lg);color:var(--color-text-muted);font-size:14px;padding:36px 24px;text-align:center}.students-table-wrap{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden}.students-table td,.students-table th{border-bottom:1px solid var(--color-border);font-size:13.5px;padding:12px 16px;text-align:left}.students-table th{background:var(--color-surface-subtle);color:var(--color-text-muted);font-size:11.5px}.students-table td{color:var(--color-text)}.students-table tbody tr:last-child td{border-bottom:0}.students-table tbody tr:hover{background-color:var(--color-surface-subtle)}.pagination-info{background:var(--color-surface-subtle);border-top:1px solid var(--color-border);color:var(--color-text-muted);font-size:12.5px;padding:12px 16px}.order-lists-page{background-color:var(--color-bg);min-height:100%;padding:24px 28px}.order-lists-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:20px}.order-lists-header h1{color:var(--color-text);font-size:22px;font-weight:700;letter-spacing:-.2px;margin:0}.order-lists-filters .filter-select{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:inherit;font-size:13.5px;min-width:180px;outline:none;padding:9px 12px}.order-lists-filters .filter-select:hover{border-color:var(--color-border-strong)}.order-lists-filters .filter-select:focus{border-color:var(--color-primary)}.order-lists-error{background:var(--color-danger-soft);border:1px solid #fecdca;border-radius:var(--radius-md);color:var(--color-danger);font-size:13.5px;margin-bottom:16px;padding:10px 14px}.order-lists-table-wrap{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);overflow:hidden}.order-lists-table{border-collapse:collapse;width:100%}.order-lists-table td,.order-lists-table th{border-bottom:1px solid var(--color-border);font-size:13.5px;padding:12px 16px;text-align:left}.order-lists-table th{background:var(--color-surface-subtle);color:var(--color-text-muted);font-size:11.5px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.order-lists-table td{color:var(--color-text)}.order-lists-table tbody tr:last-child td{border-bottom:0}.order-lists-table tbody tr:hover{background-color:var(--color-surface-subtle)}.status-badge{align-items:center;border:1px solid #0000;border-radius:999px;display:inline-flex;font-size:11.5px;padding:2px 10px}.status-completed{background:var(--color-success-soft);border-color:#abefc6;color:var(--color-success)}.status-pending{background:var(--color-warning-soft);border-color:#fedf89;color:var(--color-warning)}.status-cancelled,.status-failed{background:var(--color-danger-soft);border-color:#fecdca;color:var(--color-danger)}.status-refunded{background:var(--color-surface-subtle);border-color:var(--color-border);color:var(--color-text-muted)}.status-processing{background:var(--color-info-soft);border-color:#b2ddff;color:var(--color-info)}.order-lists-pagination{align-items:center;background:var(--color-surface-subtle);border-top:1px solid var(--color-border);color:var(--color-text-muted);display:flex;font-size:12.5px;gap:12px;padding:12px 16px}.order-lists-pagination button{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:500;padding:6px 12px;transition:background-color .12s ease,border-color .12s ease}.order-lists-pagination button:disabled{cursor:not-allowed;opacity:.5}.order-lists-pagination button:not(:disabled):hover{background:var(--color-surface-subtle);border-color:var(--color-border-strong)}.feedback-page{background-color:var(--color-bg);min-height:100%;padding:24px 28px}.feedback-header{margin-bottom:20px}.feedback-header h1{color:var(--color-text);font-size:22px;font-weight:700;letter-spacing:-.2px;margin:0 0 4px}.feedback-subtitle{color:var(--color-text-muted);font-size:13px;margin:0 0 14px}.feedback-search{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-family:inherit;font-size:13.5px;outline:none;padding:9px 12px;width:280px}.feedback-search:hover{border-color:var(--color-border-strong)}.feedback-search:focus{border-color:var(--color-primary)}.feedback-error{background:var(--color-danger-soft);border:1px solid #fecdca;border-radius:var(--radius-md);color:var(--color-danger);font-size:13.5px;margin-bottom:16px;padding:10px 14px}.feedback-list{display:flex;flex-direction:column;gap:10px}.feedback-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:14px 18px;transition:box-shadow .15s ease,border-color .15s ease}.feedback-item:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-sm)}.feedback-item-header{align-items:center;display:flex;gap:8px;margin-bottom:8px}.feedback-user{color:var(--color-text);font-size:13.5px;font-weight:600}.feedback-context{background:var(--color-surface-subtle);border:1px solid var(--color-border);border-radius:999px;color:var(--color-text-muted);font-size:11px;font-weight:600;letter-spacing:.4px;padding:2px 8px;text-transform:uppercase}.feedback-content{color:var(--color-text);font-size:13.5px;line-height:1.55;margin:0 0 8px}.feedback-meta{align-items:center;color:var(--color-text-subtle);display:flex;font-size:12px;gap:10px}.feedback-rating{align-items:center;color:var(--color-warning);display:inline-flex;font-weight:600;gap:4px}.mentor-profile{margin:0 auto;max-width:800px;padding:20px}.mentor-profile-header{margin-bottom:30px}.mentor-profile-header h1{font-size:28px;font-weight:600;margin-bottom:8px}.mentor-profile-header p{color:#666;font-size:14px}.mentor-profile-form{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:30px}.form-section{display:flex;flex-direction:column;gap:24px}.form-input,.form-select,.form-textarea{border:1px solid #ddd;border-radius:6px;font-family:inherit;padding:10px 12px;transition:border-color .2s}.form-input:focus,.form-select:focus,.form-textarea:focus{box-shadow:0 0 0 3px #f59e0b1a;outline:none}.profile-image-preview{border:1px solid #ddd;border-radius:8px;margin-top:12px;overflow:hidden;width:120px}.profile-image-preview img{display:block;height:auto;width:100%}.file-input{padding:8px}.success-message{border-radius:6px;font-size:14px;margin-bottom:16px;padding:12px 16px}.form-actions{margin-top:30px;padding-top:30px}.mentor-directory{margin:0 auto;max-width:1200px;padding:20px}.directory-header{margin-bottom:30px}.directory-header h1{font-size:28px;font-weight:600;margin-bottom:8px}.directory-header p{color:#666;font-size:14px}.directory-filters{display:flex;gap:12px;margin-bottom:24px}.subject-filter{margin-bottom:30px}.filter-label{color:#333;font-weight:500;margin-bottom:12px}.filter-buttons{display:flex;flex-wrap:wrap;gap:8px}.filter-btn{background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 16px;transition:all .2s}.filter-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.filter-btn.active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.mentors-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));margin-bottom:30px}.mentor-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;cursor:pointer;overflow:hidden;transition:all .2s}.mentor-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.mentor-image{background:#f5f5f5;height:200px;overflow:hidden;width:100%}.mentor-image img{height:100%;object-fit:cover;width:100%}.mentor-info{padding:16px}.mentor-name{color:#333;font-size:16px;font-weight:600;margin:0 0 8px}.mentor-subject{color:var(--color-primary);font-size:12px;font-weight:500;margin:0 0 8px}.mentor-bio{color:#666;font-size:13px;line-height:1.4;margin:0}.course-revenue{margin:0 auto;max-width:1200px;padding:20px}.revenue-header{margin-bottom:30px}.revenue-header h1{font-size:28px;font-weight:600;margin:0}.revenue-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:30px}.revenue-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:20px}.card-value{color:#333;font-size:24px;margin-bottom:8px}.card-meta{color:#999;font-size:12px}.charts-section{grid-gap:20px;gap:20px;grid-template-columns:1fr 1fr;margin-bottom:30px}.chart-container{padding:20px}.chart-empty{color:#999;font-size:14px;padding:40px 20px;text-align:center}.payments-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:24px}.payments-section h2{color:#333;font-size:18px;font-weight:600;margin:0 0 20px}.payment-filters{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:20px}.payment-filters input,.payment-filters select{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px}.payment-filters input:focus,.payment-filters select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a;outline:none}.payments-table{border-collapse:collapse;margin-bottom:20px;width:100%}.payments-table thead{background-color:#f5f5f5;border-bottom:1px solid #eee}.payments-table th{color:#333;font-size:14px;font-weight:600;padding:16px;text-align:left}.payments-table td{border-bottom:1px solid #eee;font-size:14px;padding:16px}.payments-table tbody tr:hover{background-color:#fafafa}.status-badge.completed{background-color:#e8f5e9;color:#2e7d32}@media (max-width:768px){.charts-section,.payment-filters{grid-template-columns:1fr}.payments-table{font-size:12px}.payments-table td,.payments-table th{padding:12px 8px}}.quiz-results{margin:0 auto;max-width:1000px;padding:20px}.results-header{margin-bottom:30px}.results-header h1{font-size:28px;font-weight:600;margin:0}.stats-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.quiz-results-page .stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:18px;text-align:center}.quiz-results-page .stat-label{color:var(--color-text-muted);font-size:12px;font-weight:600;letter-spacing:.4px;margin-bottom:6px;text-transform:uppercase}.quiz-results-page .stat-value{color:var(--color-primary);font-size:26px;font-weight:700}.chart-container{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px;padding:24px}.chart-container h3{color:#333;font-size:16px;font-weight:600;margin:0 0 20px}.insights-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px;padding:24px}.insights-section h3{color:#333;font-size:16px;font-weight:600;margin:0 0 20px}.insight-box{background-color:#f0f0ff;border-left:4px solid var(--color-primary);border-radius:6px;margin-bottom:16px;padding:16px}.insight-box.warning{background-color:#fff3e0;border-left-color:#ff9800}.insight-box.info{background-color:#e0f7fa;border-left-color:#00bcd4}.insight-box h4{color:#333;font-size:14px;font-weight:600;margin:0 0 12px}.insight-box ul{list-style:none;margin:0;padding:0}.insight-box li{color:#555;font-size:13px;line-height:1.5;padding:8px 0}.insight-box li:not(:last-child){border-bottom:1px solid #0000001a}.attempts-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:24px}.attempts-section h2{color:#333;font-size:18px;font-weight:600;margin:0 0 20px}.attempts-table{border-collapse:collapse;margin-bottom:20px;width:100%}.attempts-table thead{background-color:#f5f5f5;border-bottom:1px solid #eee}.attempts-table th{color:#333;font-size:14px;font-weight:600;padding:16px;text-align:left}.attempts-table td{border-bottom:1px solid #eee;font-size:14px;padding:16px}.attempts-table tbody tr:hover{background-color:#fafafa}.status-badge.passed{background-color:#e8f5e9;color:#2e7d32}.status-badge.failed{background-color:#ffebee;color:#c62828}.btn-action{border:1px solid var(--color-primary)}.modal-content{border-radius:8px;box-shadow:0 4px 24px #0003;max-height:90vh;max-width:600px;overflow-y:auto}.modal-header{background:#fff;padding:20px;position:sticky;top:0}.modal-header h3{font-size:16px;font-weight:600;margin:0}.modal-close{font-size:24px}.attempt-summary{grid-gap:16px;background:#f9f9f9;border-radius:6px;display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-bottom:24px;padding:16px}.summary-item{display:flex;flex-direction:column;gap:4px}.summary-item span{color:#666;font-size:12px}.summary-item strong{color:#333;font-size:14px}.attempt-answers h4{font-size:14px;font-weight:600;margin:0 0 16px}.answer-item{border:1px solid #eee;border-radius:6px;margin-bottom:12px;padding:16px}.answer-item h5{color:#333;font-size:13px;font-weight:600;margin:0 0 12px}.correct-answer,.student-answer{border-radius:4px;margin-bottom:8px;padding:8px}.correct-answer,.student-answer{background-color:#f5f5f5}.correct-answer.correct{background-color:#e8f5e9}.correct-answer.incorrect{background-color:#ffebee}.correct-answer strong,.student-answer strong{display:block;font-size:12px;margin-bottom:4px}.correct-answer p,.student-answer p{color:#333;font-size:13px;margin:0}.course-analytics{margin:0 auto;max-width:1000px;padding:20px}.analytics-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.analytics-header h1{font-size:28px;font-weight:600;margin:0}.header-actions{display:flex;gap:12px}.cache-info{background:#f5f5f5;border-radius:4px;color:#999;font-size:12px;margin-bottom:20px;padding:8px 12px}.analytics-cards{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:30px}.analytics-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:20px;text-align:center}.card-label{font-weight:500;margin-bottom:8px}.card-value{color:var(--color-primary)}.analytics-nav{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.nav-link{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;color:var(--color-primary);display:block;font-weight:500;padding:20px;text-decoration:none;transition:all .2s}.nav-link:hover{box-shadow:0 4px 16px #f59e0b4d;transform:translateY(-2px)}.lesson-metrics{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:30px;padding:24px}.lesson-metrics h2{color:#333;font-size:18px;font-weight:600;margin:0 0 20px}.metrics-table{border-collapse:collapse;width:100%}.metrics-table thead{background-color:#f5f5f5;border-bottom:1px solid #eee}.metrics-table th{color:#333;font-size:14px;font-weight:600;padding:16px;text-align:left}.metrics-table td{border-bottom:1px solid #eee;font-size:14px;padding:16px}.metrics-table tbody tr:hover{background-color:#fafafa}.progress-bar{align-items:center;display:flex;gap:8px}.progress-bar>div{background-color:#eee;border-radius:3px;height:6px;overflow:hidden;width:100px}.progress-bar span{color:#666;font-size:12px;font-weight:500;min-width:40px}.export-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:24px}.export-section h2{color:#333;font-size:18px;font-weight:600;margin:0 0 20px}.export-options{margin-bottom:20px}.checkbox-group{align-items:center;cursor:pointer;display:flex;font-size:14px;gap:8px;margin-bottom:12px}.checkbox-group input[type=checkbox]{cursor:pointer}.btn-secondary{background-color:#f0f0f0}.btn-secondary:hover{background-color:#e0e0e0}@media print{.analytics-header .header-actions,.export-section{display:none}.analytics-cards,.analytics-nav,.lesson-metrics{page-break-inside:avoid}}.analytics-date-range{align-items:flex-end;background:#f9f9fb;border:1px solid #eee;border-radius:8px;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px;padding:12px 16px}.analytics-date-range label{color:#555;display:flex;flex-direction:column;font-size:12px;gap:4px}.analytics-date-range input[type=date]{background:#fff;border:1px solid #ddd;border-radius:6px;font-size:13px;padding:6px 10px}.virtualized-table-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.virtualized-table-header{align-items:center;background:var(--color-surface-subtle);border-bottom:1px solid var(--color-border);display:grid;grid-auto-flow:column;min-height:44px;position:sticky;top:0;z-index:10}.virtualized-table-header-cell{border-right:1px solid var(--color-border);color:var(--color-text-muted);font-size:12px;font-weight:600;letter-spacing:.4px;overflow:hidden;padding:10px 14px;text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap}.virtualized-table-header-cell:last-child{border-right:none}.virtualized-table-row{align-items:center;border-bottom:1px solid var(--color-border);cursor:pointer;display:grid;grid-auto-flow:column;transition:background-color .15s ease}.virtualized-table-row:hover{background-color:var(--color-surface-subtle)}.virtualized-table-row:active{background-color:var(--color-primary-soft)}.virtualized-table-cell{border-right:1px solid var(--color-border);color:var(--color-text);font-size:13.5px;overflow:hidden;padding:12px 14px;text-overflow:ellipsis;white-space:nowrap}.virtualized-table-cell:last-child{border-right:none}.virtualized-table-empty{align-items:center;color:var(--color-text-subtle);display:flex;font-size:13.5px;height:200px;justify-content:center}.student-progress{margin:0 auto;max-width:1200px;padding:20px}.progress-header{margin-bottom:30px}.progress-header h1{font-size:28px;font-weight:600;margin:0}.progress-filters{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.filter-select,.search-input{border-radius:6px;padding:10px 12px}.progress-content{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 350px}.students-table-section{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.students-table th{font-size:14px}.students-table tbody tr{cursor:pointer;transition:background-color .2s}.status-badge.cancelled{background-color:#ffebee;color:#c62828}.progress-bar{background-color:#eee;margin-bottom:4px;width:100%}.progress-fill{background-color:var(--color-primary)}.pagination{padding:20px}.student-detail-panel{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;max-height:calc(100vh - 40px);overflow-y:auto;padding:20px;position:sticky;top:20px}.detail-header{border-bottom:1px solid #eee;margin-bottom:20px;padding-bottom:20px}.detail-header h3{color:#333;font-size:16px;margin:0}.detail-info{border-bottom:1px solid #eee;margin-bottom:24px;padding-bottom:24px}.info-item{align-items:center;display:flex;font-size:13px;justify-content:space-between;padding:8px 0}.info-item span{color:#999}.info-item strong{color:#333}.detail-metrics{grid-gap:12px;border-bottom:1px solid #eee;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:24px;padding-bottom:24px}.metric{background:#f9f9f9;border-radius:6px;gap:4px;padding:12px;text-align:center}.metric span{color:#999;font-size:12px}.metric strong{color:var(--color-primary);font-size:18px}.activity-timeline{font-size:13px}.activity-timeline h4{color:#333;font-size:13px;font-weight:600;margin:0 0 12px}.activity-item{border-bottom:1px solid #eee;padding:8px 0}.activity-item:last-child{border-bottom:none}.activity-time{font-size:11px;margin-bottom:2px}.activity-description{color:#666;line-height:1.4}@media (max-width:1024px){.progress-content{grid-template-columns:1fr}.student-detail-panel{max-height:none;position:relative;top:auto}}.dropoff-analysis{margin:0 auto;max-width:1000px;padding:20px}.dropoff-header{margin-bottom:30px}.dropoff-header h1{font-size:28px;font-weight:600;margin:0 0 8px}.dropoff-header p{color:#666;font-size:14px;margin:0}.dropoff-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px;overflow:hidden;width:100%}.dropoff-table thead{background-color:#f5f5f5;border-bottom:1px solid #eee}.dropoff-table th{color:#333;font-size:14px;font-weight:600;padding:16px;text-align:left}.dropoff-table td{border-bottom:1px solid #eee;font-size:14px;padding:16px}.dropoff-table tbody tr{transition:background-color .2s}.dropoff-table tbody tr:hover{background-color:#fafafa}.dropoff-table tbody tr.high-dropoff{background-color:#ffebee}.dropoff-meter{align-items:center;display:flex;gap:8px;margin-bottom:4px}.dropoff-bar{background-color:#eee;border-radius:4px;flex:1 1;height:8px;max-width:150px;overflow:hidden}.btn-view{background:#fff;border:1px solid var(--color-primary);border-radius:4px;color:var(--color-primary);font-size:12px;padding:6px 12px}.btn-view:hover{background-color:#f0f0ff}.dropped-students-panel{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:24px}.panel-header{align-items:center;border-bottom:1px solid #eee;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:20px}.panel-header h3{color:#333;font-size:16px;margin:0}.close-btn{background:none;border:none;color:#999;cursor:pointer;font-size:24px}.students-list{display:flex;flex-direction:column;gap:8px}.student-item{align-items:center;background:#f9f9f9;border-radius:6px;display:flex;font-size:14px;justify-content:space-between;padding:12px}.student-name{color:#333;font-weight:500}.student-progress{color:#999;font-size:12px}.empty{color:#999;padding:20px;text-align:center}.course-certificates{margin:0 auto;max-width:1000px;padding:20px}.certificates-header{margin-bottom:30px}.certificates-header h1{font-size:28px;font-weight:600;margin:0 0 8px}.certificates-header p{color:#666;font-size:14px;margin:0}.certificates-table{background:#fff;border-collapse:collapse;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;overflow:hidden;width:100%}.certificates-table thead{background-color:#f5f5f5;border-bottom:1px solid #eee}.certificates-table th{color:#333;font-size:14px;font-weight:600;padding:16px;text-align:left}.certificates-table td{border-bottom:1px solid #eee;font-size:14px;padding:16px}.certificates-table tbody tr:hover{background-color:#fafafa}.status-badge.generated{background-color:#e8f5e9;color:#2e7d32}.status-badge.pending{background-color:#fff3e0;color:#e65100}.status-badge.in-progress{background-color:#eef2ff;color:#4338ca}.bulk-toolbar{align-items:center;background:#f9f9fb;border:1px solid #eee;border-radius:8px;display:flex;gap:12px;justify-content:space-between;margin-bottom:16px;padding:12px 16px}.bulk-toolbar label{align-items:center;color:#444;display:flex;font-size:14px;gap:8px}.info-message{background-color:#e8f5e9;border-radius:6px;color:#2e7d32;font-size:14px;margin-bottom:12px;padding:10px 14px}.actions{display:flex;flex-wrap:wrap;gap:8px}.btn-action{background:#fff;border:1px solid #ddd;border-radius:4px;color:var(--color-primary);cursor:pointer;display:inline-block;font-size:12px;padding:6px 12px;text-decoration:none;transition:all .2s}.btn-action:hover{background-color:#f0f0ff;border-color:var(--color-primary)}.btn-action.btn-primary{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-action.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.btn-action:disabled{cursor:not-allowed;opacity:.6}.pagination{padding-top:20px}.pagination-btn{background:#fff}.pagination-btn:hover:not(:disabled){color:var(--color-primary)}.thread-item{border:1px solid #eee;border-radius:8px;transition:all .2s}.thread-item:hover{background:#f9f9ff;border-color:var(--color-primary);box-shadow:0 2px 8px #f59e0b1a}.thread-item.answered{border-left:4px solid #4caf50}.thread-item.unanswered{border-left:4px solid #ffc107}.thread-header{align-items:flex-start;display:flex;gap:12px;margin-bottom:8px}.thread-title{color:#333;flex:1 1;font-size:16px}.notification-indicator{background-color:#ff6b6b;border-radius:12px;color:#fff;flex-shrink:0;font-size:12px;font-weight:600;min-width:24px;padding:2px 8px;text-align:center}.thread-preview{color:#666;font-size:14px;line-height:1.4;margin:0 0 12px}.thread-meta{color:#999;gap:8px}.author{color:#666;font-weight:500}.separator{color:#ddd}.time{color:#999}.lesson{background-color:#f0f0f0;border-radius:3px;color:#666;font-size:11px;padding:2px 8px}.thread-stats{align-items:center;gap:20px;margin-left:20px}.stat{gap:4px}.stat-value{color:#333;font-weight:600}.status-column{align-items:center;display:flex;margin-left:12px;min-width:100px}.status-badge{font-weight:500;white-space:nowrap}.status-badge.answered{background-color:#e8f5e9;color:#2e7d32}.status-badge.unanswered{background-color:#fff3e0;color:#e65100}@media (max-width:768px){.thread-item{flex-direction:column}.thread-stats{border-top:1px solid #eee;margin-left:0;margin-top:12px;padding-top:12px;width:100%}.thread-header{flex-direction:column}.notification-indicator{align-self:flex-end}}.thread-detail{margin:0 auto;max-width:900px;padding:20px}.detail-header{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:24px}.btn-status{background:#fff;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.btn-status:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-status.answered{background-color:#e8f5e9;border-color:#4caf50;color:#2e7d32}.btn-status.unanswered{background-color:#fff3e0;border-color:#ffc107;color:#e65100}.question-section,.replies-section,.reply-form-section{margin-bottom:32px}.section-title{border-bottom:2px solid #f0f0f0;color:#333;font-size:16px;font-weight:600;margin-bottom:16px;padding-bottom:12px}.question-card{border:1px solid #eee;border-radius:8px;box-shadow:0 2px 4px #0000000d;padding:24px}.question-header{align-items:flex-start;gap:12px;margin-bottom:16px}.question-header h2{color:#333;flex:1 1;font-size:24px;font-weight:600;margin:0}.answered-badge{background-color:#e8f5e9;border-radius:4px;color:#2e7d32;font-size:12px;font-weight:600;padding:4px 12px;white-space:nowrap}.question-content{color:#666;font-size:15px;line-height:1.6;margin:0 0 20px}.question-meta{border-top:1px solid #eee;color:#666;flex-wrap:wrap;font-size:14px;padding-top:16px}.meta-item{align-items:center;display:flex;gap:8px}.meta-item strong{color:#333}.replies-list{display:flex;flex-direction:column;gap:12px}.reply-card{background:#fff;border:1px solid #eee;border-left:4px solid #f0f0f0;border-radius:8px;padding:16px;transition:all .2s}.reply-card:hover{box-shadow:0 2px 8px #0000000d}.reply-card.teacher-reply{background-color:#f9f9ff;border-left-color:var(--color-primary)}.reply-header{justify-content:space-between;margin-bottom:12px}.reply-author{align-items:center;display:flex;gap:8px}.reply-author strong{color:#333;font-size:14px}.teacher-badge{background-color:var(--color-primary);border-radius:3px;color:#fff;font-size:11px;font-weight:600;padding:2px 8px}.reply-time{color:#999}.reply-content{color:#666;font-size:14px;line-height:1.5;margin:0;white-space:pre-wrap;word-break:break-word}.btn-delete-reply{background:#fff;border:1px solid #d32f2f;border-radius:4px;color:#d32f2f;cursor:pointer;font-size:12px;margin-top:12px;padding:6px 12px;transition:all .2s}.btn-delete-reply:hover{background-color:#ffebee}.no-replies{background:#f9f9f9;border-radius:8px;color:#999;padding:40px;text-align:center}.reply-form-section{background:#fff;border:1px solid #eee;border-radius:8px;padding:24px}.reply-form{margin-top:16px}.form-group{position:relative}.form-group textarea{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;padding:12px;width:100%}.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a;outline:none}.char-count{bottom:-20px;position:absolute;right:0}.form-actions{padding-top:16px}@media (max-width:768px){.thread-detail{padding:12px}.detail-header{align-items:stretch;flex-direction:column}.btn-back{text-align:left}.question-header{flex-direction:column}.question-header h2{font-size:18px}.question-meta{gap:12px}.form-actions,.question-meta{flex-direction:column}.btn{width:100%}}.course-qa{margin:0 auto;max-width:1200px;padding:20px}.qa-header{align-items:center;margin-bottom:30px}.qa-header h1{font-size:28px;font-weight:600}.new-thread-card{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px;padding:24px}.new-thread-card h3{font-size:16px;font-weight:600;margin:0 0 20px}.form-group label{color:#333;display:block;font-weight:500;margin-bottom:8px}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a;outline:none}.form-group textarea{resize:vertical}.form-actions{border-top:1px solid #eee;margin-top:20px;padding-top:20px}.btn{border-radius:6px;font-weight:500;padding:10px 20px;transition:all .2s}.btn-primary:hover:not(:disabled){background-color:var(--color-primary-hover);box-shadow:0 4px 12px #f59e0b4d}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-cancel{background-color:#f0f0f0}.btn-cancel:hover{background-color:#e0e0e0}.btn-pagination{background-color:#f0f0f0;color:#333;font-size:13px;padding:8px 16px}.btn-pagination:hover:not(:disabled){background-color:#e0e0e0}.btn-pagination:disabled{cursor:not-allowed;opacity:.5}.qa-controls{gap:16px;margin-bottom:24px}.search-box{flex:1 1}.search-box input{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:10px 12px;width:100%}.search-box input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a;outline:none}.filters{display:flex;gap:12px}.filter-select{border-radius:6px;padding:10px 12px}.pagination{gap:12px}.pagination-info{min-width:120px}@media (max-width:768px){.qa-header{align-items:flex-start}.qa-controls,.qa-header{flex-direction:column;gap:12px}.filters{flex-direction:column}.filter-select,.filters{width:100%}}.conversation-list{display:flex;flex-direction:column;gap:8px}.conversation-item{background:#fff;border:1px solid #eee;border-radius:8px;cursor:pointer;display:flex;gap:12px;padding:12px;position:relative;transition:all .2s}.conversation-item:hover{background:#f9f9ff;border-color:var(--color-primary);box-shadow:0 2px 8px #f59e0b1a}.conversation-item.unread{background-color:#f0f0ff;border-color:var(--color-primary)}.conversation-avatar{flex-shrink:0;position:relative}.avatar-initials{font-size:14px;height:48px;width:48px}.online-indicator{background-color:#4caf50;border:2px solid #fff;border-radius:50%;bottom:0;height:12px;position:absolute;right:0;width:12px}.conversation-content{flex:1 1;min-width:0}.conversation-header{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:4px}.participant-name{color:#333;flex:1 1;font-size:14px;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.last-message-time{color:#999;flex-shrink:0;font-size:12px}.last-message{color:#666;font-size:13px;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conversation-item.unread .last-message{color:#333;font-weight:500}.unread-badge{background-color:#ff6b6b;border-radius:12px;color:#fff;font-size:11px;font-weight:600;min-width:24px;padding:2px 8px;position:absolute;right:8px;text-align:center;top:8px}@media (max-width:768px){.conversation-item{gap:10px;padding:10px}.avatar-initials{font-size:12px;height:40px;width:40px}.participant-name{font-size:13px}.last-message{font-size:12px}}.message-detail-view{background:#fff;display:flex;flex-direction:column;height:100vh;margin:0 auto;max-width:900px}.message-detail-header{align-items:center;background:#fff;border-bottom:1px solid #eee;display:flex;gap:16px;padding:16px 20px}.btn-back:hover{color:var(--color-primary-hover)}.header-info{flex:1 1}.header-info h2{color:#333;font-size:18px;font-weight:600;margin:0}.online-status{color:#4caf50;display:inline-block;font-size:12px;font-weight:500;margin-top:2px}.messages-container{background:#f9f9f9;flex:1 1;overflow-y:auto;padding:16px 20px}.no-messages{align-items:center;color:#999;display:flex;height:100%;justify-content:center;text-align:center}.messages-list{display:flex;flex-direction:column;gap:12px}.message-item{align-items:flex-end;display:flex;gap:12px}.message-item.sent{justify-content:flex-end}.message-avatar{flex-shrink:0}.avatar-initials{align-items:center;background:linear-gradient(135deg,var(--color-primary),#8a92ff);border-radius:50%;color:#fff;display:flex;font-size:12px;font-weight:600;height:32px;justify-content:center;width:32px}.message-content{max-width:70%}.message-item.sent .message-content{align-self:flex-end;max-width:70%}.message-bubble{background:#fff;border-radius:8px;box-shadow:0 1px 2px #0000001a;padding:10px 14px}.message-item.sent .message-bubble{background:var(--color-primary);border-bottom-right-radius:2px;color:#fff}.message-item.received .message-bubble{border-bottom-left-radius:2px}.message-bubble p{font-size:14px;line-height:1.4;margin:0;white-space:pre-wrap;word-break:break-word}.message-time{color:#999;font-size:11px;margin-top:4px}.message-item.sent .message-time,.message-time{text-align:right}.message-item.received .message-time{text-align:left}.message-input-form{background:#fff;border-top:1px solid #eee;padding:16px 20px}.message-input-form textarea{border:1px solid #ddd;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;resize:none;transition:all .2s;width:100%}.message-input-form textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a;outline:none}.message-input-form textarea:disabled{background-color:#f5f5f5;color:#999}.input-actions{align-items:center;display:flex;justify-content:space-between;margin-top:8px}.char-count{color:#999}.btn-send{background-color:var(--color-primary);border-radius:6px;font-weight:500;padding:8px 20px;transition:all .2s}.btn-send:hover:not(:disabled){background-color:var(--color-primary-hover);box-shadow:0 4px 12px #f59e0b4d}.btn-send:disabled{opacity:.6}@media (max-width:768px){.message-detail-view{height:auto;max-width:100%}.message-detail-header{padding:12px 16px}.header-info h2{font-size:16px}.messages-container{max-height:60vh;padding:12px 16px}.message-content,.message-item.sent .message-content{max-width:85%}.message-input-form{padding:12px 16px}}.direct-messaging{margin:0 auto;max-width:1200px;padding:20px}.messaging-header{align-items:baseline;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.messaging-header h1{color:var(--color-text);font-size:24px;font-weight:700;letter-spacing:-.4px;margin:0}.header-info{align-items:center;color:var(--color-text-muted);display:inline-flex;font-size:13px;font-weight:500;gap:8px}.header-info:before{color:var(--color-text-subtle);content:"·";font-size:18px;line-height:1}.search-section{margin-bottom:24px}.search-input{border-radius:6px;max-width:400px;padding:10px 12px;transition:all .2s;width:100%}.search-input:focus{box-shadow:0 0 0 3px #f59e0b1a}.empty-state{background:#f9f9f9;border-radius:8px}.error-message{background-color:#ffebee;color:#c62828;font-size:14px;padding:12px 16px}.loading{color:#999}.realtime-indicator{background:#f5f5f5;border-radius:6px;color:#999;font-size:12px;justify-content:center;margin-top:24px;padding:12px}.pulse{animation:pulse 2s infinite;background-color:#4caf50}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width:768px){.direct-messaging{padding:12px}.messaging-header{align-items:flex-start;flex-direction:column;gap:8px}.messaging-header h1{font-size:24px}.search-input{max-width:100%}}.teachers-page{margin:0 auto;max-width:1400px;padding:20px}.teachers-header{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-bottom:30px}.teachers-header h1{color:#333;font-size:28px;font-weight:600;margin:0}.teachers-header-actions{display:flex;gap:10px}.teachers-content{display:flex;flex-direction:column;gap:20px}.teachers-primary-btn{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-hover) 100%);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.teachers-primary-btn:hover:not(:disabled){box-shadow:0 8px 16px #667eea66;transform:translateY(-2px)}.teachers-primary-btn:disabled{cursor:not-allowed;opacity:.6}.teachers-submit-btn{background:var(--color-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .3s ease;width:100%}.teachers-submit-btn:hover:not(:disabled){background:#5568d3;box-shadow:0 4px 12px #667eea66}.teachers-submit-btn:disabled{cursor:not-allowed;opacity:.6}.teachers-back-btn{background:#f0f0f0;border:1px solid #ddd;border-radius:8px;color:#333;cursor:pointer;font-size:14px;padding:10px 16px;transition:all .3s ease}.teachers-back-btn:hover{background:#e8e8e8}.teachers-page .btn-action{background:var(--color-primary);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;padding:8px 16px;transition:all .3s ease}.teachers-page .btn-action:hover{background:var(--color-primary-hover)}.teachers-page .btn-remove{background:#ff6b6b;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;padding:8px 16px;transition:all .3s ease}.teachers-page .btn-remove:hover{background:#ee5a52}.btn-action-sm,.btn-remove-sm{border:none;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;margin-bottom:8px;padding:8px 12px;transition:all .3s ease;width:100%}.btn-action-sm{background:var(--color-primary);color:#fff}.btn-action-sm:hover{background:#5568d3}.btn-remove-sm{background:#ff6b6b;color:#fff}.btn-remove-sm:hover{background:#ee5a52}.teacher-accept-form,.teacher-form,.teacher-invite-card,.teacher-login-form{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.teacher-form-group{margin-bottom:20px}.teacher-form-group label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.teacher-form-group input,.teacher-form-group textarea{border:1px solid #ddd;border-radius:8px;font-family:inherit;font-size:14px;padding:12px;transition:border-color .3s ease;width:100%}.teacher-form-group input:focus,.teacher-form-group textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a;outline:none}.teacher-form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.teacher-form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.teacher-form-error,.teachers-error{background:#fee;border-left:4px solid #c33;color:#c33}.teacher-form-error,.teachers-error,.teachers-success{border-radius:8px;font-size:14px;margin-bottom:16px;padding:12px}.teachers-success{background:#efe;border-left:4px solid #3c3;color:#3c3}.teacher-login-page{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-hover) 100%);display:flex;justify-content:center;min-height:100vh;padding:20px}.teacher-accept-card,.teacher-login-card{background:#fff;border-radius:12px;box-shadow:0 10px 40px #00000026;max-width:400px;padding:40px;width:100%}.teacher-accept-card h1,.teacher-login-title{color:#333;font-size:28px;font-weight:700;margin:0 0 8px;text-align:center}.teacher-accept-subtitle,.teacher-login-subtitle{color:#666;font-size:14px;margin-bottom:30px;text-align:center}.teacher-login-footer{color:#666;font-size:13px;margin-top:20px;text-align:center}.teacher-accept-page{align-items:center;background:#f5f5f5;display:flex;justify-content:center;min-height:100vh;padding:20px}.teacher-accept-card{max-width:500px}.teacher-accept-card.error-state{text-align:center}.teacher-accept-card.error-state h1{color:#c33}.teacher-accept-card.success-state{text-align:center}.teacher-accept-card.success-state h1{color:#1f7a4d}.teacher-accept-info,.teacher-invite-info{background:#f9f9f9;border-radius:8px;color:#666;font-size:13px;line-height:1.6;margin-top:20px;padding:16px}.assign-students-table-wrap,.teachers-table-wrap{overflow-x:auto}.teachers-table{background:#fff;border-collapse:collapse;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden;width:100%}.teachers-table thead{background:#f9f9f9;border-bottom:2px solid #eee}.teachers-table th{color:#666;font-size:13px;font-weight:600;padding:16px;text-align:left;text-transform:uppercase}.teachers-table tbody tr{border-bottom:1px solid #eee;transition:background .2s ease}.teachers-table tbody tr:hover{background:#fafafa}.teachers-table td{color:#333;font-size:14px;padding:16px}.teachers-table td.numeric{font-weight:600;text-align:right}.teachers-table td.empty-state{color:#999;padding:40px 16px;text-align:center}.teacher-info{align-items:center;display:flex;gap:12px}.teacher-avatar{border-radius:50%;height:40px;object-fit:cover;width:40px}.contact-info{color:#666;font-size:13px}.contact-info div{margin-bottom:4px}.action-buttons{flex-wrap:wrap;gap:8px}.teachers-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.teacher-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;padding:20px;transition:all .3s ease}.teacher-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.teacher-card-avatar{border-radius:50%;height:80px;margin:0 auto 16px;object-fit:cover;width:80px}.teacher-card h3{color:#333;font-size:18px;margin:0 0 12px;text-align:center}.teacher-card-contact{margin-bottom:16px;text-align:center}.teacher-card-contact p{color:#666;font-size:13px;margin:4px 0}.teacher-card-stats{grid-gap:12px;border-bottom:1px solid #eee;border-top:1px solid #eee;display:grid;gap:12px;grid-template-columns:1fr 1fr;margin-bottom:16px;padding:12px 0}.teacher-card-stats .stat{align-items:center;display:flex;flex-direction:column}.stat-value{color:var(--color-primary);font-size:18px}.stat-label{color:#999;font-size:12px;margin-top:4px}.teacher-card-meta{color:#999;font-size:12px;margin-bottom:16px}.teacher-card-actions{margin-top:auto}.teachers-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.teachers-page .stat-card{background:linear-gradient(135deg,var(--color-primary) 0,#8b5cf6 100%);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);color:#fff;padding:20px;text-align:center}.teachers-page .stat-card h3{font-size:26px;font-weight:700;margin:0 0 6px}.teachers-page .stat-card p{font-size:13px;margin:0;opacity:.9}.assign-controls,.teachers-controls{align-items:center;display:flex;flex-wrap:wrap;gap:16px}.search-input{border:1px solid #ddd;border-radius:8px;flex:1 1;font-size:14px;min-width:200px;padding:10px 16px;transition:border-color .3s ease}.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #667eea1a;outline:none}.result-count{color:#666;font-size:13px;white-space:nowrap}.teacher-toggle-pending{background:#f0f0f0;border:1px solid #ddd;border-radius:8px;color:#333;cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:all .3s ease}.teacher-toggle-pending:hover{background:#e8e8e8}.assign-students-card,.teacher-invitations-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.teacher-invitations-list{margin-top:20px}.modal-overlay{background:#00000080}.modal-content{box-shadow:0 10px 40px #0000004d;max-width:400px;padding:24px}.modal-content h3{color:#333;font-size:20px;margin:0 0 16px}.modal-content p{color:#666;font-size:14px;line-height:1.6;margin:0 0 20px}.modal-actions{justify-content:flex-end}.btn-cancel,.btn-confirm-delete{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .3s ease}.btn-cancel{background:#f0f0f0}.btn-cancel:hover{background:#e8e8e8}.btn-confirm-delete{background:#ff6b6b;color:#fff}.btn-confirm-delete:hover{background:#ee5a52}.btn-cancel:disabled,.btn-confirm-delete:disabled{cursor:not-allowed;opacity:.6}.empty-state-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:60px 24px;text-align:center}.empty-state-card h3{color:#333;font-size:18px;margin:0 0 8px}.empty-state-card p{color:#666;font-size:14px;margin:0 0 20px}input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer;height:18px;width:18px}input[type=checkbox]:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.teachers-page{padding:16px}.teachers-header{align-items:flex-start;flex-direction:column}.teachers-header h1{font-size:22px}.teacher-form-row{grid-template-columns:1fr}.teachers-table td,.teachers-table th{font-size:12px;padding:12px}.action-buttons{flex-direction:column}.btn-action,.btn-remove{margin-bottom:8px;width:100%}.teachers-grid,.teachers-stats{grid-template-columns:1fr}.modal-content{padding:20px}.assign-controls{align-items:stretch;flex-direction:column}.search-input{min-width:auto}}@media (max-width:480px){.teacher-accept-card,.teacher-login-card{padding:24px 16px}.teacher-login-title{font-size:22px}.teachers-table{font-size:12px}.action-buttons{gap:4px}}.searchable-dropdown{display:inline-block;max-width:400px;position:relative;width:100%}.searchable-dropdown[disabled]{opacity:.6;pointer-events:none}.dropdown-button{align-items:center;background:#fff;border:1px solid #d0d0d0;border-radius:6px;cursor:pointer;display:flex;font-size:14px;justify-content:space-between;padding:10px 12px;transition:all .2s ease;width:100%}.dropdown-button:hover:not(:disabled){border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a}.dropdown-button:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b33;outline:none}.dropdown-label{color:#333;flex:1 1;text-align:left}.dropdown-arrow{color:#666;margin-left:8px;transition:transform .2s ease}.dropdown-arrow.open{transform:rotate(0deg)}.dropdown-menu{background:#fff;border:1px solid #d0d0d0;border-radius:0 0 6px 6px;border-top:none;box-shadow:0 4px 6px #0000001a;display:flex;flex-direction:column;left:0;max-height:300px;position:absolute;right:0;top:100%;z-index:1000}.dropdown-search{border:none;border-bottom:1px solid #e0e0e0;border-radius:0;font-size:14px;padding:10px 12px}.dropdown-search:focus{background-color:#f9f9f9;outline:none}.dropdown-items{flex:1 1;overflow-x:hidden;overflow-y:auto}.dropdown-item{align-items:center;border-bottom:1px solid #f5f5f5;cursor:pointer;display:flex;justify-content:space-between;padding:10px 12px;transition:background-color .15s ease}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background-color:#f0f4ff}.dropdown-item.selected{background-color:#e8f0ff;color:var(--color-primary);font-weight:500}.dropdown-item span:first-child{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.checkmark{color:#29cc97;font-weight:700;margin-left:8px}.dropdown-empty{color:#999;font-size:13px;padding:20px 12px;text-align:center}.dropdown-loading{color:#666;font-size:13px;padding:10px 12px;text-align:center}.load-more-btn{background:#fff;border:none;border-top:1px solid #e0e0e0;color:var(--color-primary);cursor:pointer;font-size:13px;font-weight:500;padding:10px 12px;transition:background-color .2s ease;width:100%}.load-more-btn:hover{background-color:#f9f9f9}.dropdown-items::-webkit-scrollbar{width:6px}.dropdown-items::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.dropdown-items::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.dropdown-items::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.teacher-dashboard{background-color:#f5f6fa;min-height:100%;padding:32px}.course-selector-section{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;gap:16px;margin-bottom:24px;padding:20px}.course-label{color:#202224;font-weight:600;min-width:120px}.course-selector{background-color:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;flex:1 1;font-family:Nunito Sans,sans-serif;padding:10px 16px}.course-selector:focus,.course-selector:hover{border-color:var(--color-primary)}.course-selector:focus{box-shadow:0 0 0 3px #f59e0b1a;outline:none}.filters-section{grid-gap:16px;display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.filter-select,.search-input{background-color:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-family:Nunito Sans,sans-serif;font-size:14px;padding:10px 16px}.search-input::placeholder{color:#999}.filter-select:focus,.search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a;outline:none}.students-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;overflow:hidden}.empty-state{color:#999}.empty-state p{font-size:16px}.students-table{border-collapse:collapse;width:100%}.students-table thead{background-color:#f5f5f5;border-bottom:1px solid #eee}.students-table th{color:#333;font-size:13px;font-weight:600;letter-spacing:.5px;padding:16px;text-align:left;text-transform:uppercase}.students-table td{border-bottom:1px solid #eee;color:#333;font-size:14px;padding:16px}.name-cell,.status-badge{font-weight:600}.status-badge{border-radius:4px;display:inline-block;font-size:12px;padding:4px 12px;text-transform:capitalize}.status-badge.active{background-color:#e8f5e9;color:#2e7d32}.status-badge.completed{background-color:#e3f2fd;color:#1565c0}.status-badge.at-risk{background-color:#fff3e0;color:#e65100}.progress-bar-cell{align-items:center;display:flex;gap:8px}.progress-bar{flex:1 1;min-width:100px}.progress-text{color:#666;font-size:12px;font-weight:600;min-width:40px;text-align:right}.centered{text-align:center}.btn-view{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;padding:6px 16px;transition:background-color .2s}.students-table tbody tr:hover{background-color:#fafafa}.pagination{border-top:1px solid #eee}.pagination-info{min-width:150px}@media (max-width:1024px){.filters-section{grid-template-columns:1fr}.students-table{font-size:13px}.students-table td,.students-table th{padding:12px}}@media (max-width:768px){.teacher-dashboard{padding:16px}.dashboard-header h1{font-size:24px}.course-selector-section{align-items:flex-start;flex-direction:column}.students-table{font-size:12px}.students-table td,.students-table th{padding:8px}.students-table tbody td:not(:first-child),.students-table thead th:not(:first-child){display:none}.students-table tbody tr{border-top:2px solid #eee;display:block}.students-table td{display:block;padding-left:50%;position:relative;text-align:right}.students-table td:before{content:attr(data-label);font-weight:700;left:6px;position:absolute;text-align:left}.btn-view{display:block;text-align:center;width:100%}}.at-risk-badge{background-color:#fff3cd;border:1px solid #ffc107;border-radius:4px;color:#856404;display:inline-block;font-size:11px;font-weight:600;margin-left:8px;padding:2px 8px;vertical-align:middle}.student-detail{background-color:#f5f6fa;min-height:100%;padding:32px}.detail-header{margin-bottom:32px}.student-info-header h1{color:#202224;font-size:32px;font-weight:700;margin:0}.student-email{font-size:16px;margin:8px 0 0}.overview-cards{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:32px}.card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:24px}.card-label{color:#666;font-size:13px;font-weight:600;letter-spacing:.5px;margin-bottom:12px;text-transform:uppercase}.card-value{color:#202224;font-size:28px;font-weight:700;margin-bottom:12px}.card-date{color:#999;font-size:12px;margin-bottom:12px}.progress-bar-card{background-color:#f0f0f0;border-radius:4px;height:8px;margin-top:16px;overflow:hidden}.chart-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;margin-bottom:32px;padding:24px}.chart-section h2{color:#202224;font-size:20px;font-weight:700;margin:0 0 24px}.lessons-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;margin-bottom:32px;padding:24px}.lessons-section h2{color:#202224;font-size:20px;font-weight:700;margin:0 0 24px}.empty-message{color:#999;margin:0;padding:40px 0;text-align:center}.lessons-list{display:flex;flex-direction:column;gap:16px}.lesson-item{border:1px solid #eee;border-radius:8px;padding:16px;transition:all .2s}.lesson-item:hover{background-color:#f9f9ff;border-color:var(--color-primary)}.lesson-title{color:#202224;font-size:15px;font-weight:600;margin-bottom:12px}.lesson-progress{align-items:center;display:flex;gap:12px;margin-bottom:12px}.lesson-progress .progress-bar{background-color:#f0f0f0;border-radius:3px;flex:1 1;height:6px;overflow:hidden}.lesson-progress span{color:#666;font-size:13px;font-weight:600;min-width:40px;text-align:right}.lesson-meta{align-items:center;display:flex;gap:12px}.badge-completed{background-color:#e8f5e9;border-radius:4px;color:#2e7d32;font-size:12px;font-weight:600;padding:4px 8px}.lesson-date{color:#999;font-size:12px}.activity-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;margin-bottom:32px;padding:24px}.activity-section h2{color:#202224;font-size:20px;font-weight:700;margin:0 0 24px}.activity-list{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.activity-item{background-color:#f9f9ff;border-left:3px solid var(--color-primary);border-radius:4px;padding:12px}.activity-time{color:#999;font-size:12px;font-weight:600;margin-bottom:4px}.activity-description{color:#333;font-size:14px}.action-buttons{gap:16px;margin-top:32px}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.btn-primary{background-color:var(--color-primary)}.btn-primary:hover{background-color:#3d57d4}.btn-secondary{background-color:#f5f5f5;border:1px solid #ddd;color:#333}.btn-secondary:hover{background-color:#e8e8e8}.btn-message{background-color:#10b981;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.btn-message:hover{background-color:#059669}.message-panel{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-top:24px;overflow:hidden}.message-panel-header{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:16px 20px}.message-panel-header h3{color:#111827;font-size:16px;font-weight:600;margin:0}.btn-close-panel{background:none;border:none;color:#6b7280;cursor:pointer;font-size:18px;line-height:1;padding:0 4px}.btn-close-panel:hover{color:#374151}.message-history{background:#f9fafb;display:flex;flex-direction:column;gap:10px;max-height:300px;overflow-y:auto;padding:16px 20px}.msg-empty,.msg-loading{color:#6b7280;font-size:14px;padding:20px 0;text-align:center}.msg-bubble{border-radius:12px;font-size:14px;line-height:1.5;max-width:75%;padding:10px 14px}.msg-bubble p{color:inherit;margin:0 0 4px}.msg-sent{align-self:flex-end;background:var(--color-primary);border-bottom-right-radius:4px;color:#fff}.msg-received{align-self:flex-start;background:#fff;border:1px solid #e5e7eb;border-bottom-left-radius:4px;color:#374151}.msg-time{font-size:11px;opacity:.7}.message-compose{align-items:flex-end;border-top:1px solid #e5e7eb;display:flex;gap:10px;padding:14px 20px}.message-compose textarea{border:1px solid #e5e7eb;border-radius:8px;color:#374151;flex:1 1;font-family:inherit;font-size:14px;padding:10px 12px;resize:none}.message-compose textarea:focus{border-color:var(--color-primary);outline:none}.btn-send{background:var(--color-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:opacity .15s;white-space:nowrap}.btn-send:disabled{cursor:not-allowed;opacity:.5}.btn-send:hover:not(:disabled){background:#4f46e5}.error-message{border-radius:6px;margin:0 20px 12px;padding:8px 12px}@media (max-width:768px){.student-detail{padding:16px}.student-info-header h1{font-size:24px}.overview-cards{grid-template-columns:1fr}.action-buttons{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.quiz-feedback{background-color:#f5f6fa;min-height:100%;padding:32px}.feedback-header{margin-bottom:32px}.btn-back{font-size:16px;margin-bottom:16px;transition:color .2s}.btn-back:hover{color:#3d57d4}.header-content h1{color:#202224;font-size:32px;font-weight:700;margin:0}.header-subtitle{color:#666;font-size:16px;margin:8px 0 0}.success-message{align-items:center;background-color:#e8f5e9;border-left:4px solid #2e7d32;border-radius:8px;color:#2e7d32;display:flex;font-weight:600;gap:12px;margin-bottom:24px;padding:16px}.success-message svg{flex-shrink:0}.feedback-container{grid-gap:32px;display:grid;gap:32px;grid-template-columns:1fr 1fr}.feedback-form-card,.quiz-details-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:24px}.feedback-form-card h2,.quiz-details-card h2{color:#202224;font-size:20px;font-weight:700;margin:0 0 20px}.detail-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:24px}.detail-item{display:flex;flex-direction:column;gap:6px}.detail-item .label{color:#666;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.detail-item .value{color:#202224;font-size:16px;font-weight:600}.detail-item .value.score{color:var(--color-primary);font-size:18px}.questions-section{border-top:1px solid #eee;margin-top:24px;padding-top:24px}.questions-section h3{color:#202224;font-size:16px;font-weight:700;margin:0 0 16px}.questions-list{display:flex;flex-direction:column;gap:12px}.question-item{background-color:#f9f9f9;border:1px solid #eee;border-left:4px solid #ddd;border-radius:8px;padding:16px}.question-item.correct{background-color:#f1f8f5;border-left-color:#2e7d32}.question-item.incorrect{background-color:#fef2f2;border-left-color:#b91c1c}.question-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.question-number{color:#333;font-size:13px;font-weight:600}.question-status{border-radius:4px;font-size:12px;font-weight:600;padding:4px 8px}.question-status.correct{background-color:#e8f5e9;color:#2e7d32}.question-status.incorrect{background-color:#ffebee;color:#b91c1c}.question-text{color:#333;font-size:14px;font-weight:500;margin-bottom:8px}.correct-answer,.student-answer{color:#666;font-size:13px;margin-bottom:4px}.correct-answer strong,.student-answer strong{color:#333;font-weight:600}.correct-answer{color:#2e7d32}.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.form-group label{color:#202224;font-size:14px;font-weight:600}.form-group small{color:#999;font-size:12px}.score-input-group{align-items:center;display:flex;gap:8px}.score-input{border:1px solid #ddd;border-radius:8px;flex:1 1;font-family:Nunito Sans,sans-serif;font-size:14px;padding:10px 12px}.score-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a;outline:none}.score-helper{color:#666;font-size:14px;font-weight:600;min-width:40px}.feedback-textarea,.suggestions-textarea{border:1px solid #ddd;border-radius:8px;color:#333;font-family:Nunito Sans,sans-serif;font-size:14px;padding:12px;resize:vertical}.feedback-textarea::placeholder,.suggestions-textarea::placeholder{color:#999}.feedback-textarea:focus,.suggestions-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a;outline:none}.form-actions{gap:12px;margin-top:24px}@media (max-width:1024px){.feedback-container{grid-template-columns:1fr}}@media (max-width:768px){.quiz-feedback{padding:16px}.header-content h1{font-size:24px}.detail-grid{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-cancel,.btn-submit{width:100%}}.at-risk-dashboard{background-color:#f5f6fa;min-height:100%;padding:32px}.dashboard-header{margin-bottom:32px}.dashboard-header h1{color:#202224;font-size:32px;font-weight:700;letter-spacing:-.11px;margin:0}.filters-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;flex-wrap:wrap;gap:16px;margin-bottom:24px;padding:20px}.filter-group,.filters-section{align-items:center;display:flex}.filter-group{gap:8px}.filter-group label{color:#333;font-size:14px;font-weight:600;min-width:120px}.filter-select{background-color:#fff;border:1px solid #ddd;font-family:Nunito Sans,sans-serif;min-width:150px;padding:10px 16px}.filter-select:hover{border-color:var(--color-primary)}.filter-select:focus{box-shadow:0 0 0 3px #f59e0b1a}.students-container{width:100%}.empty-state{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:60px 20px}.empty-state svg{color:#ccc;margin-bottom:16px}.empty-state p{color:#333;font-size:18px;font-weight:600;margin:0}.empty-subtitle{color:#999;font-size:14px;margin-top:8px!important}.students-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));margin-bottom:32px}.student-card{background:#fff;border-left:4px solid #ddd;border-radius:12px;box-shadow:0 2px 8px #0000000d;overflow:hidden;padding:24px;position:relative;transition:all .2s}.student-card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-2px)}.student-card.risk-high{background:linear-gradient(135deg,#fff5f5,#fff);border-left-color:#ff6b6b}.student-card.risk-medium{background:linear-gradient(135deg,#fff9f0,#fff);border-left-color:#ffa94d}.student-card.risk-low{background:linear-gradient(135deg,#f5f8ff,#fff);border-left-color:var(--color-primary)}.risk-badge{border-radius:6px;display:inline-block;font-size:12px;font-weight:600;margin-bottom:12px;padding:6px 12px}.risk-badge.risk-high{background-color:#ffebee;color:#b91c1c}.risk-badge.risk-medium{background-color:#fff3e0;color:#e65100}.risk-badge.risk-low{background-color:#e3f2fd;color:#1565c0}.student-header{margin-bottom:16px}.student-header h3{color:#202224;font-size:18px;font-weight:700;margin:0 0 4px}.student-email{color:#666;font-size:13px;margin:0}.metrics{grid-gap:16px;border-bottom:1px solid #eee;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:20px;padding-bottom:20px}.metric{display:flex;flex-direction:column;gap:6px}.metric-label{color:#666;font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.metric-value{font-size:20px}.metric-value.score-high{color:#ff6b6b}.metric-value.score-medium{color:#ffa94d}.metric-value.score-low{color:#2e7d32}.risk-reasons{background-color:#00000005;border-radius:8px;margin-bottom:20px;padding:12px}.risk-reasons h4{color:#666;font-size:12px;font-weight:600;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.risk-reasons ul{display:flex;flex-direction:column;gap:6px;list-style:none;margin:0;padding:0}.risk-reasons li{color:#333;font-size:13px;margin:0;padding-left:16px;position:relative}.risk-reasons li:before{color:#ff6b6b;content:"•";font-weight:700;left:0;position:absolute}.progress-indicator{margin-bottom:20px}.progress-bar{background-color:#f0f0f0;border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,var(--color-primary) 0,#29cc97 100%);height:100%;transition:width .3s ease}.progress-label{color:#666;font-size:12px;font-weight:600}.action-buttons{display:flex;gap:12px}.btn-message,.btn-view{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:13px;font-weight:600;padding:10px 12px;text-align:center;transition:all .2s}.btn-message{background-color:#e3f2fd;color:#1565c0}.btn-message:hover{background-color:#bbdefb}.btn-view{background-color:var(--color-primary);color:#fff}.btn-view:hover{background-color:#3d57d4}.pagination{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;gap:16px;justify-content:center;margin-top:24px;padding:24px}.pagination-btn{background-color:#f5f5f5;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s}.pagination-btn:hover:not(:disabled){background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-info{color:#666;font-size:14px;min-width:200px;text-align:center}.modal-overlay{background-color:#00000080;bottom:0;left:0;right:0;top:0}.modal-content{animation:slideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:90%}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:1px solid #eee;padding:24px}.modal-header h2{color:#202224;font-size:20px;font-weight:700;margin:0}.modal-close{align-items:center;color:#999;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:color .2s;width:32px}.modal-close:hover{color:#333}.modal-body{padding:24px}.message-textarea{border:1px solid #ddd;border-radius:8px;color:#333;font-family:Nunito Sans,sans-serif;font-size:14px;padding:12px;resize:vertical;width:100%}.message-textarea::placeholder{color:#999}.message-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f59e0b1a;outline:none}.modal-actions{border-top:1px solid #eee;display:flex;gap:12px;padding:24px}.btn-cancel,.btn-submit{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;padding:12px 24px;transition:all .2s}.btn-submit{background-color:var(--color-primary);color:#fff}.btn-submit:hover:not(:disabled){background-color:#3d57d4}.btn-submit:disabled{cursor:not-allowed;opacity:.6}.btn-cancel{background-color:#f5f5f5;border:1px solid #ddd;color:#333}.btn-cancel:hover:not(:disabled){background-color:#e8e8e8}.btn-cancel:disabled{cursor:not-allowed;opacity:.6}@media (max-width:1200px){.students-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}}@media (max-width:768px){.at-risk-dashboard{padding:16px}.dashboard-header h1{font-size:24px}.filter-group,.filters-section{align-items:flex-start;flex-direction:column}.filter-group,.filter-select{width:100%}.metrics,.students-grid{grid-template-columns:1fr}.action-buttons{flex-direction:column}.btn-message,.btn-view{width:100%}.modal-content{width:95%}}.risk-group{margin-bottom:32px}.risk-group-title{border-bottom:2px solid;font-size:18px;font-weight:600;margin-bottom:16px;padding-bottom:8px}.risk-amber,.risk-group-title.risk-amber{border-color:#ffc107;color:#856404}.risk-group-title.risk-red,.risk-red{border-color:#dc3545;color:#842029}.student-card.risk-card-amber{background-color:#fffdf0;border-left:4px solid #ffc107}.student-card.risk-card-red{background-color:#fff5f5;border-left:4px solid #dc3545}.risk-badge.risk-amber{background-color:#fff3cd;border:1px solid #ffc107;color:#856404}.risk-badge.risk-red{background-color:#f8d7da;border:1px solid #dc3545;color:#842029}.student-course{color:#6c757d;font-size:13px;margin:2px 0 4px}.notification-body{color:#495057;font-size:13px;font-style:italic;margin:4px 0 8px}.btn-dismiss{background-color:initial;border:1px solid #dee2e6;border-radius:6px;color:#6c757d;cursor:pointer;font-size:13px;padding:8px 16px;transition:background-color .2s}.btn-dismiss:hover:not(:disabled){background-color:#f8f9fa;color:#495057}.btn-dismiss:disabled{cursor:not-allowed;opacity:.6}.teacher-metrics{background-color:#f5f6fa;min-height:100%;padding:32px}.header{margin-bottom:32px}.header h1{color:#202224;font-size:32px;font-weight:700;letter-spacing:-.11px;margin:0}.subtitle{color:#666;font-size:14px;margin:8px 0 0}.error-message{background-color:#fef2f2;border-left:4px solid #b91c1c;color:#b91c1c;margin-bottom:24px;padding:16px}.loading{color:#666;font-size:16px}.course-selector{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;gap:16px;margin-bottom:24px;padding:20px}.course-selector label{color:#202224;font-weight:600;min-width:120px}.course-select{background-color:#fff;border:1px solid #ddd;border-radius:8px;cursor:pointer;flex:1 1;font-family:Nunito Sans,sans-serif;font-size:14px;padding:10px 16px}.course-select:focus,.course-select:hover{border-color:var(--color-primary)}.course-select:focus{box-shadow:0 0 0 3px #f59e0b1a;outline:none}.metrics-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:32px}.metric-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;gap:16px;padding:24px;transition:all .2s}.metric-card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-2px)}.metric-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;font-size:28px;height:60px;justify-content:center;width:60px}.metric-icon.enrollment{background-color:#e3f2fd}.metric-icon.completion{background-color:#e8f5e9}.metric-icon.engagement{background-color:#fff3e0}.metric-icon.average{background-color:#f3e5f5}.metric-icon.at-risk{background-color:#ffebee}.metric-icon.retention{background-color:#e0f2f1}.metric-details{display:flex;flex:1 1;flex-direction:column;justify-content:center}.metric-details h3{color:#666;font-size:13px;font-weight:600;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.metric-value{color:#202224;font-size:28px;font-weight:700;margin-bottom:4px}.metric-change{color:#666;font-size:13px;font-weight:600}.metric-change.positive{color:#2e7d32}.charts-section{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:32px}.chart-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:24px}.chart-card.full-width{grid-column:1/-1}.chart-card h2{color:#202224;font-size:18px;font-weight:700;margin:0 0 24px}.insights-section{margin-bottom:32px}.insights-section h2{color:#202224;font-size:20px;font-weight:700;margin:0 0 24px}.insights-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.insight-card{background:#fff;border-left:4px solid #ddd;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:24px;transition:all .2s}.insight-card:hover{box-shadow:0 8px 24px #0000001f;transform:translateY(-2px)}.insight-card.insight-positive{background:linear-gradient(135deg,#f1f8f5,#fff);border-left-color:#2e7d32}.insight-card.insight-warning{background:linear-gradient(135deg,#fff5f5,#fff);border-left-color:#ff6b6b}.insight-card.insight-info{background:linear-gradient(135deg,#f5f8ff,#fff);border-left-color:var(--color-primary)}.insight-icon{font-size:24px;margin-bottom:12px}.insight-content h3{color:#202224;font-size:16px;font-weight:700;margin:0 0 8px}.insight-content p{color:#666;font-size:14px;line-height:1.5;margin:0 0 12px}.insight-action{background-color:var(--color-primary);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:8px 16px;transition:background-color .2s}.insight-action:hover{background-color:#3d57d4}.empty-insights{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:40px;text-align:center}.empty-insights p{color:#999;margin:0}.recommendations-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:24px}.recommendations-section h2{color:#202224;font-size:20px;font-weight:700;margin:0 0 24px}.recommendations-list{display:flex;flex-direction:column;gap:16px}.recommendation-item{background-color:#f9f9f9;border-left:4px solid var(--color-primary);border-radius:8px;display:flex;gap:16px;padding:16px}.rec-number{align-items:center;background-color:var(--color-primary);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-weight:700;height:40px;justify-content:center;width:40px}.rec-content h4{color:#202224;font-size:15px;font-weight:700;margin:0 0 8px}.rec-content p{color:#666;font-size:14px;line-height:1.5;margin:0 0 8px}.rec-impact{background-color:#e8f5e9;border-radius:4px;color:#2e7d32;display:inline-block;font-size:12px;font-weight:600;padding:8px}@media (max-width:1200px){.charts-section{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}}@media (max-width:768px){.teacher-metrics{padding:16px}.header h1{font-size:24px}.course-selector{align-items:flex-start;flex-direction:column}.course-select{width:100%}.charts-section,.insights-grid,.metrics-grid{grid-template-columns:1fr}.metric-card{flex-direction:column}.metric-icon{height:50px;width:50px}.recommendations-list{gap:12px}.recommendation-item{flex-direction:column}.rec-number{font-size:14px;height:32px;width:32px}}.teacher-qa{max-width:900px;padding:24px}.qa-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;margin-bottom:20px}.qa-header h1{color:#111827;font-size:24px;font-weight:700;margin:0}.qa-header-subtitle{align-items:center;display:flex;gap:8px}.urgency-legend{align-items:center;color:#6b7280;display:flex;font-size:12px;gap:6px}.dot{border-radius:50%;display:inline-block;height:10px;width:10px}.dot-amber{background:#f59e0b}.dot-red{background:#ef4444}.course-selector{color:#374151;font-size:14px;gap:10px;margin-bottom:16px}.course-selector,.qa-controls{align-items:center;display:flex}.qa-controls{gap:12px;margin-bottom:20px}.filter-select{background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;font-size:14px;padding:8px 12px}.filter-select:focus{border-color:var(--color-primary);outline:none}.thread-count{color:#6b7280;font-size:13px}.thread-list{display:flex;flex-direction:column;gap:12px}.thread-item{align-items:flex-start;background:#fff;border:1px solid #e5e7eb;border-left:4px solid #9ca3af;border-radius:12px;cursor:pointer;display:flex;justify-content:space-between;padding:16px;transition:box-shadow .15s,border-color .15s}.thread-item:hover{box-shadow:0 4px 12px #00000014}.thread-item.answered{border-left-color:#10b981;opacity:.85}.thread-item.unanswered{border-left-color:var(--color-primary)}.thread-item.urgency-amber{background:#fffbeb;border-left-color:#f59e0b}.thread-item.urgency-red{background:#fef2f2;border-left-color:#ef4444}.thread-content{flex:1 1;min-width:0}.thread-item-header{align-items:center;display:flex;gap:8px;margin-bottom:6px}.thread-title{color:#111827;font-size:15px;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.urgency-badge{border-radius:999px;font-size:11px;font-weight:700;padding:2px 8px;white-space:nowrap}.urgency-badge-amber{background:#fef3c7;color:#92400e}.urgency-badge-red{background:#fee2e2;color:#991b1b}.thread-preview{color:#6b7280;font-size:13px;line-height:1.5;margin:0 0 8px}.thread-meta{align-items:center;color:#9ca3af;display:flex;font-size:12px;gap:4px}.separator{color:#d1d5db}.thread-stats{align-items:flex-end;flex-shrink:0;gap:8px;margin-left:16px}.stat,.thread-stats{display:flex;flex-direction:column}.stat{align-items:center}.stat-value{color:#374151;font-size:16px;font-weight:700}.stat-label{color:#9ca3af;font-size:11px}.badge,.status-badge{border-radius:999px;font-size:12px;font-weight:600;padding:3px 10px}.badge-answered,.thread-item.answered .status-badge{background:#d1fae5;color:#065f46}.badge-open{background:#ede9fe;color:#4c1d95}.badge-teacher{background:#dbeafe;color:#1e40af;font-size:11px;padding:2px 8px}.qa-detail-header{align-items:center;display:flex;gap:12px;margin-bottom:20px}.btn-back{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:14px;font-weight:600;padding:0}.btn-back:hover{text-decoration:underline}.question-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:24px;padding:20px}.question-card h2{color:#111827;font-size:18px;font-weight:700;margin:0 0 12px}.question-body{color:#374151;font-size:14px;line-height:1.6;margin:0 0 12px}.question-meta{color:#6b7280;display:flex;font-size:13px;gap:20px}.replies-section{margin-bottom:24px}.replies-section h3{color:#111827;font-size:16px;font-weight:600;margin:0 0 12px}.empty-replies{color:#6b7280;font-size:14px}.reply-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:10px;padding:14px}.reply-card.teacher-reply{background:#eff6ff;border-color:#bfdbfe}.reply-header{align-items:center;color:#374151;display:flex;font-size:14px;gap:8px;margin-bottom:8px}.reply-time{color:#9ca3af;font-size:12px;margin-left:auto}.reply-card p{color:#374151;font-size:14px;line-height:1.5;margin:0}.reply-form{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:16px;padding:20px}.reply-form h3{color:#111827;font-size:16px;font-weight:600;margin:0 0 12px}.reply-form textarea{border:1px solid #e5e7eb;border-radius:8px;box-sizing:border-box;color:#374151;font-family:inherit;font-size:14px;padding:10px 12px;resize:vertical;width:100%}.reply-form textarea:focus{border-color:var(--color-primary);outline:none}.char-count{color:#9ca3af;font-size:12px;margin-bottom:12px;margin-top:4px;text-align:right}.form-actions{display:flex;gap:10px;justify-content:flex-end}.btn{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;padding:9px 20px;transition:opacity .15s}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:#4f46e5}.btn-cancel{background:#f3f4f6;border:1px solid #e5e7eb}.empty-state,.loading{color:#6b7280;padding:40px;text-align:center}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;font-size:13px;margin-bottom:16px;padding:10px 14px}.realtime-indicator{align-items:center;color:#9ca3af;display:flex;gap:8px;margin-top:20px}.pulse{animation:pulse-anim 2s infinite;background:#10b981;border-radius:50%;display:inline-block;height:8px;width:8px}@keyframes pulse-anim{0%,to{opacity:1}50%{opacity:.4}}.statistics-page{background-color:var(--color-bg);min-height:100%;padding:24px 28px}.statistics-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.statistics-title{color:var(--color-text);font-size:22px;font-weight:700;letter-spacing:-.2px;margin:0}.statistics-subtitle{color:var(--color-text-muted);font-size:13.5px;margin-top:4px}.stats-period-tabs{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;flex-shrink:0;gap:2px;padding:4px}.stats-period-tab{background:none;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;font-family:inherit;font-size:12.5px;font-weight:500;padding:6px 14px;transition:background-color .12s ease,color .12s ease;white-space:nowrap}.stats-period-tab.active{background:var(--color-primary);box-shadow:var(--shadow-xs);color:var(--color-primary-contrast)}.stats-period-tab:not(.active):hover{background:var(--color-surface-subtle);color:var(--color-text)}.stats-error,.stats-loading{color:var(--color-text-muted);font-size:14px;padding:60px 24px;text-align:center}.stats-error{color:var(--color-danger)}.stats-skeleton{animation:shimmer 1.4s infinite;background:linear-gradient(90deg,var(--color-surface-subtle) 25%,var(--color-border) 50%,var(--color-surface-subtle) 75%);background-size:200% 100%;border-radius:var(--radius-md)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.stats-kpi-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}@media (max-width:1200px){.stats-kpi-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:600px){.stats-kpi-grid{grid-template-columns:1fr}}.stats-kpi-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);border-top:3px solid #0000;box-shadow:var(--shadow-xs);display:flex;flex-direction:column;gap:6px;padding:18px 20px;transition:box-shadow .2s ease,border-color .2s ease}.stats-kpi-card:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-md)}.stats-kpi-label{color:var(--color-text-subtle);font-size:11.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase}.stats-kpi-value{color:var(--color-text);font-size:26px;font-weight:700;letter-spacing:-.3px;line-height:1.1}.stats-kpi-sub{color:var(--color-text-muted);font-size:12px;margin-top:2px}.stats-kpi-badge{align-items:center;border:1px solid #0000;border-radius:999px;display:inline-flex;font-size:11.5px;font-weight:600;gap:3px;padding:2px 8px;width:fit-content}.stats-kpi-badge.positive{background:var(--color-success-soft);border-color:#abefc6;color:var(--color-success)}.stats-kpi-badge.neutral{background:var(--color-surface-subtle);border-color:var(--color-border);color:var(--color-text-muted)}.stats-kpi-badge.warning{background:var(--color-warning-soft);border-color:#fedf89;color:var(--color-warning)}.stats-section-header{align-items:center;display:flex;gap:10px;margin-bottom:14px;margin-top:8px}.stats-section-title{color:var(--color-text);font-size:16px;font-weight:700;letter-spacing:-.1px}.stats-section-divider{background:var(--color-border);flex:1 1;height:1px}.stats-row-2{grid-gap:20px;grid-template-columns:2fr 1fr}.stats-row-2,.stats-row-equal{display:grid;gap:20px;margin-bottom:24px}.stats-row-equal{grid-gap:20px;grid-template-columns:repeat(2,1fr)}.stats-row-3{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(3,1fr);margin-bottom:24px}@media (max-width:1100px){.stats-row-2,.stats-row-3,.stats-row-equal{grid-template-columns:1fr}}.stats-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:20px 22px;transition:box-shadow .2s ease}.stats-card:hover{box-shadow:var(--shadow-md)}.stats-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.stats-card-title{color:var(--color-text);font-size:15px;font-weight:600}.stats-card-badge{background:var(--color-primary-soft);border:1px solid #fde68a;border-radius:999px;color:var(--color-primary-accent);font-size:11.5px;font-weight:600;padding:3px 10px}.stats-chart-empty{align-items:center;color:var(--color-text-subtle);display:flex;font-size:13px;height:200px;justify-content:center}.stats-summary-list{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}.stats-summary-item{align-items:center;background:var(--color-surface-subtle);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;justify-content:space-between;padding:10px 14px}.stats-summary-label{color:var(--color-text-muted);font-size:13px}.stats-summary-value{color:var(--color-text);font-size:13.5px;font-weight:700}.stats-highlight{color:var(--color-primary-accent)}.stats-engage-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr);margin-bottom:24px}@media (max-width:900px){.stats-engage-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:550px){.stats-engage-grid{grid-template-columns:1fr}}.stats-engage-card{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);display:flex;gap:14px;padding:16px 18px}.stats-engage-icon{align-items:center;border-radius:var(--radius-md);display:flex;flex-shrink:0;font-size:18px;height:42px;justify-content:center;width:42px}.stats-engage-label{color:var(--color-text-subtle);font-size:11.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}.stats-engage-value{color:var(--color-text);font-size:20px;font-weight:700;letter-spacing:-.2px;line-height:1.2}.stats-engage-sub{color:var(--color-text-subtle);font-size:11px}.stats-progress-item{margin-bottom:14px}.stats-progress-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.stats-progress-label{color:var(--color-text-muted);font-size:13px;font-weight:500}.stats-progress-pct{color:var(--color-text);font-size:13px;font-weight:700}.stats-progress-track{background:var(--color-surface-subtle);border:1px solid var(--color-border);border-radius:999px;height:7px;overflow:hidden}.stats-progress-fill{border-radius:999px;height:100%;transition:width .8s cubic-bezier(.25,1,.5,1)}.stats-table{border-collapse:collapse;width:100%}.stats-table th{background:var(--color-surface-subtle);color:var(--color-text-muted);font-size:11.5px;font-weight:600;letter-spacing:.06em;padding:10px 12px;text-align:left;text-transform:uppercase}.stats-table td,.stats-table th{border-bottom:1px solid var(--color-border)}.stats-table td{color:var(--color-text);font-size:13.5px;padding:12px}.stats-table tr:last-child td{border-bottom:none}.stats-table tr:hover td{background:var(--color-surface-subtle)}.stats-table td:last-child,.stats-table th:last-child{text-align:right}.stats-rank{align-items:center;background:var(--color-surface-subtle);border:1px solid var(--color-border);border-radius:50%;color:var(--color-text-muted);display:inline-flex;font-size:11px;font-weight:700;height:22px;justify-content:center;margin-right:8px;width:22px}.stats-rank.gold{background:var(--color-warning-soft);border-color:#fedf89;color:var(--color-warning)}.stats-rank.silver{background:var(--color-surface-subtle);border-color:var(--color-border-strong);color:var(--color-text-muted)}.stats-rank.bronze{background:var(--color-primary-soft);border-color:#fde68a;color:var(--color-primary-accent)}.stats-revenue-chip{background:var(--color-success-soft);border:1px solid #abefc6;border-radius:999px;color:var(--color-success);display:inline-block;font-size:12px;font-weight:600;padding:2px 10px}.stats-role-list{display:flex;flex-direction:column;gap:10px}.stats-role-item{align-items:center;display:flex;gap:10px}.stats-role-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.stats-role-label{color:var(--color-text-muted);flex:1 1;font-size:13px;text-transform:capitalize}.stats-role-count{color:var(--color-text);font-size:13px;font-weight:700}.stats-role-bar{background:var(--color-surface-subtle);border:1px solid var(--color-border);border-radius:999px;height:6px;overflow:hidden;width:80px}.stats-role-fill{border-radius:999px;height:100%}.stats-provider-list{display:flex;flex-direction:column;gap:8px}.stats-provider-item{align-items:center;background:var(--color-surface-subtle);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;justify-content:space-between;padding:10px 14px}.stats-provider-name{color:var(--color-text);font-size:13px;font-weight:600;text-transform:capitalize}.stats-provider-amount{color:var(--color-primary-accent);font-size:13px;font-weight:700}.stats-period-select{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;font-family:inherit;font-size:13px;padding:7px 12px}.stats-period-select:hover{border-color:var(--color-border-strong)}.stats-metrics-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}@media (max-width:1100px){.stats-metrics-grid{grid-template-columns:repeat(2,1fr)}}.stats-charts-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:2fr 1fr}@media (max-width:900px){.stats-charts-row{grid-template-columns:1fr}}.stats-chart-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:20px 22px}.stats-chart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.stats-chart-title{color:var(--color-text);font-size:15px;font-weight:600}.team-page{background:#f5f6fa;min-height:100%;padding:32px}.team-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:24px}.team-title{color:#202224;font-size:26px;font-weight:700;margin:0}.team-subtitle{color:#94a3b8;font-size:14px;margin-top:4px}.team-header-actions{align-items:center;display:flex;gap:10px}.team-add-btn{align-items:center;background:var(--color-primary);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:background .15s,box-shadow .15s;white-space:nowrap}.team-add-btn:hover{background:#3a5ce0;box-shadow:0 4px 12px #4c6fff59}.team-view-toggle{background:#fff;border:1px solid #e8eaf0;border-radius:10px;display:flex;gap:2px;padding:4px}.team-view-btn{align-items:center;background:none;border:none;border-radius:7px;color:#94a3b8;cursor:pointer;display:flex;font-size:16px;height:34px;justify-content:center;transition:all .15s;width:34px}.team-view-btn.active{background:var(--color-primary);color:#fff}.team-view-btn:not(.active):hover{background:#f1f5f9;color:#374151}.team-stats-strip{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}@media (max-width:900px){.team-stats-strip{grid-template-columns:repeat(2,1fr)}}@media (max-width:500px){.team-stats-strip{grid-template-columns:1fr}}.team-stat-card{align-items:center;background:#fff;border-left:4px solid #0000;border-radius:14px;box-shadow:0 1px 4px #0000000f;display:flex;gap:14px;padding:18px 20px;transition:box-shadow .2s}.team-stat-card:hover{box-shadow:0 4px 14px #00000017}.team-stat-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;font-size:20px;height:44px;justify-content:center;width:44px}.team-stat-label{color:#94a3b8;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.team-stat-value{color:#1e293b;font-size:24px;font-weight:800;line-height:1.2}.team-filters-bar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.team-search-wrap{flex:0 1 360px;min-width:220px;position:relative}.team-search-icon{color:#94a3b8;font-size:14px;left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.team-search{background:#fff;border:1px solid #e8eaf0;border-radius:10px;box-sizing:border-box;font-size:14px;outline:none;padding:10px 14px 10px 36px;transition:border-color .2s,box-shadow .2s;width:100%}.team-search:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4c6fff1a}.team-role-tabs{background:#fff;border:1px solid #e8eaf0;border-radius:10px;display:flex;gap:2px;padding:4px}.team-role-tab{background:none;border:none;border-radius:7px;color:#64748b;cursor:pointer;font-size:13px;font-weight:500;padding:7px 14px;transition:all .15s;white-space:nowrap}.team-role-tab.active{background:var(--color-primary);box-shadow:0 2px 6px #4c6fff40;color:#fff}.team-role-tab:not(.active):hover{background:#f1f5f9;color:#374151}.team-sort-select{background:#fff;border:1px solid #e8eaf0;border-radius:10px;color:#374151;cursor:pointer;font-size:13px;outline:none;padding:10px 14px}.team-skeleton{animation:team-shimmer 1.4s infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 50%,#f0f0f0 75%);background-size:200% 100%;border-radius:6px}@keyframes team-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.team-skeleton-card{background:#fff;border-radius:16px;box-shadow:0 1px 4px #0000000f;padding:24px}.team-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));margin-bottom:28px}.team-card{align-items:center;background:#fff;border-radius:16px;box-shadow:0 1px 4px #0000000f;display:flex;flex-direction:column;overflow:hidden;padding:20px 18px 16px;position:relative;text-align:center;transition:box-shadow .2s,transform .15s}.team-card:hover{box-shadow:0 8px 24px #0000001a;transform:translateY(-2px)}.team-card-top-bar{height:4px;left:0;position:absolute;right:0;top:0}.team-card-avatar{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:24px;font-weight:700;height:68px;justify-content:center;margin:10px 0;overflow:hidden;position:relative;width:68px}.team-card-avatar img{height:100%;object-fit:cover;width:100%}.team-card-status-dot{border:2px solid #fff;border-radius:50%;bottom:3px;height:13px;position:absolute;right:3px;width:13px}.team-card-name{color:#1e293b;font-size:14px;font-weight:700;margin-bottom:2px}.team-card-email,.team-card-name{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.team-card-email{color:#94a3b8;font-size:11px;margin-bottom:10px}.team-card-badges{display:flex;flex-wrap:wrap;gap:5px;justify-content:center;margin-bottom:12px}.team-card-role-badge{border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.04em;padding:3px 10px;text-transform:uppercase}.team-card-status-badge{border-radius:20px;font-size:11px;font-weight:600;padding:3px 9px}.team-card-status-badge.active{background:#dcfce7;color:#16a34a}.team-card-status-badge.inactive{background:#f3f4f6;color:#9ca3af}.team-card-status-badge.banned{background:#fef2f2;color:#ef4444}.team-card-meta{color:#cbd5e1;display:flex;flex-wrap:wrap;font-size:11px;gap:8px;justify-content:center;margin-bottom:12px}.team-card-actions{display:flex;gap:6px;justify-content:stretch;margin-top:4px;width:100%}.team-card-action-btn{align-items:center;background:#fff;border:1px solid #d0d5dd;border:1px solid var(--color-border-strong,#d0d5dd);border-radius:9px;color:#4b5563;cursor:pointer;display:inline-flex;flex:1 1;font-family:inherit;font-size:12.5px;font-weight:600;gap:5px;justify-content:center;min-height:34px;padding:7px 10px;transition:background-color .16s ease,border-color .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.team-card-action-btn svg{flex-shrink:0;height:14px;width:14px}.team-card-action-btn:hover{background:var(--color-primary-soft);border-color:var(--color-primary);box-shadow:0 2px 6px -2px #f59e0b40;color:var(--color-primary);transform:translateY(-1px)}.team-card-action-btn.warn{color:#b45309}.team-card-action-btn.warn:hover{background:#fff7ec;border-color:#fbbf24;box-shadow:0 2px 6px -2px #f59e0b40;color:#92400e}.team-card-action-btn.danger{color:#b42318;flex:0 0 38px;min-width:38px;padding:7px}.team-card-action-btn.danger:hover{background:#fef3f2;border-color:#fda29b;box-shadow:0 2px 6px -2px #b4231840;color:#912018}.team-card-action-btn:active{transform:translateY(0)}.team-table-wrap{background:#fff;border-radius:16px;box-shadow:0 1px 4px #0000000f;margin-bottom:28px;overflow:hidden}.team-table{border-collapse:collapse;width:100%}.team-table th{background:#f8f9fc;border-bottom:1px solid #f0f2f8;color:#94a3b8;font-size:11px;font-weight:700;letter-spacing:.06em;padding:13px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.team-table td{border-bottom:1px solid #f8f9fc;color:#374151;font-size:13px;padding:13px 16px;vertical-align:middle}.team-table tbody tr:last-child td{border-bottom:none}.team-table tbody tr:hover td{background:#fafbff}.team-member-cell{gap:10px}.team-avatar,.team-member-cell{align-items:center;display:flex}.team-avatar{border-radius:50%;color:#fff;flex-shrink:0;font-size:13px;font-weight:700;height:38px;justify-content:center;overflow:hidden;position:relative;width:38px}.team-avatar img{height:100%;object-fit:cover;width:100%}.team-avatar-status{border:2px solid #fff;border-radius:50%;bottom:1px;height:10px;position:absolute;right:1px;width:10px}.team-member-name{color:#1e293b;font-size:13px;font-weight:600}.team-member-id{color:#cbd5e1;font-size:11px}.team-role-badge{border-radius:20px;display:inline-block;font-size:11px;font-weight:700;letter-spacing:.03em;padding:3px 10px;text-transform:uppercase}.team-status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:12px;font-weight:600;gap:5px;padding:4px 10px}.team-status-badge:before{border-radius:50%;content:"";flex-shrink:0;height:6px;width:6px}.team-status-badge.active{background:#dcfce7;color:#16a34a}.team-status-badge.active:before{background:#16a34a}.team-status-badge.inactive{background:#f3f4f6;color:#9ca3af}.team-status-badge.inactive:before{background:#9ca3af}.team-status-badge.banned{background:#fef2f2;color:#ef4444}.team-status-badge.banned:before{background:#ef4444}.team-role-select{background:#f8f9fc;border:1px solid #e8eaf0;border-radius:8px;color:#374151;cursor:pointer;font-size:12px;font-weight:600;outline:none;padding:4px 8px;transition:border-color .15s}.team-role-select:hover{border-color:var(--color-primary)}.team-actions{display:flex;gap:5px}.team-action-btn{align-items:center;background:#fff;border:1px solid #e8eaf0;border-radius:8px;color:#64748b;cursor:pointer;display:flex;font-size:13px;height:30px;justify-content:center;transition:all .15s;width:30px}.team-action-btn:hover{background:#f0f4ff;border-color:var(--color-primary);color:var(--color-primary)}.team-action-btn.danger:hover{background:#fef2f2;border-color:#ef4444;color:#ef4444}.team-action-btn.warn:hover{background:#fefce8;border-color:#f59e0b;color:#b45309}.team-action-btn.success:hover{background:#f0fdf4;border-color:#22c55e;color:#16a34a}.team-empty{align-items:center;background:#fff;border-radius:16px;box-shadow:0 1px 4px #0000000f;color:#94a3b8;display:flex;flex-direction:column;justify-content:center;margin-bottom:28px;padding:64px 24px}.team-empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.team-empty-title{color:#475569;font-size:16px;font-weight:600;margin-bottom:6px}.team-empty-sub{color:#94a3b8;font-size:13px}.team-error{background:#fef2f2;border:1px solid #fca5a5;border-radius:10px;color:#ef4444;font-size:14px;margin-bottom:16px;padding:12px 16px}.team-pagination{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 4px #0000000f;display:flex;justify-content:space-between;padding:16px 20px}.team-pagination-info{color:#94a3b8;font-size:13px}.team-pagination-controls{align-items:center;display:flex;gap:4px}.team-page-btn{align-items:center;background:#fff;border:1px solid #e8eaf0;border-radius:8px;color:#475569;cursor:pointer;display:flex;font-size:13px;font-weight:500;height:36px;justify-content:center;min-width:36px;padding:0 10px;transition:all .15s}.team-page-btn.current,.team-page-btn:hover:not(:disabled){background:var(--color-primary);border-color:var(--color-primary);color:#fff}.team-page-btn.current{font-weight:700}.team-page-btn:disabled{cursor:not-allowed;opacity:.35}.team-modal-overlay{align-items:center;background:#0f172a73;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.team-modal{background:#fff;border-radius:18px;box-shadow:0 20px 60px #0000002e;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.team-modal-header{align-items:center;border-bottom:1px solid #f0f2f8;display:flex;justify-content:space-between;padding:22px 24px 16px}.team-modal-title{color:#1e293b;font-size:17px;font-weight:700}.team-modal-close{align-items:center;background:#f1f5f9;border:none;border-radius:8px;color:#64748b;cursor:pointer;display:flex;font-size:15px;height:30px;justify-content:center;width:30px}.team-modal-close:hover{background:#e2e8f0}.team-modal-body{padding:20px 24px}.team-form-grid{grid-gap:14px;display:grid;gap:14px;grid-template-columns:1fr 1fr}.team-form-full{grid-column:1/-1}.team-field{display:flex;flex-direction:column;gap:5px}.team-label{color:#475569;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.team-input,.team-select{background:#fff;border:1px solid #e8eaf0;border-radius:9px;color:#1e293b;font-size:14px;outline:none;padding:10px 12px;transition:border-color .2s,box-shadow .2s}.team-input:focus,.team-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4c6fff1a}.team-field-hint{color:#94a3b8;font-size:11px}.team-avatar-preview{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:20px;font-weight:700;height:56px;justify-content:center;margin-bottom:4px;overflow:hidden;width:56px}.team-modal-footer{border-top:1px solid #f0f2f8;display:flex;gap:10px;justify-content:flex-end;padding:14px 24px 20px}.team-btn-cancel{background:#fff;border:1px solid #e8eaf0;border-radius:9px;color:#64748b;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px}.team-btn-cancel:hover{background:#f8f9fc}.team-btn-save{background:var(--color-primary);border:none;border-radius:9px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:background .15s}.team-btn-save:hover{background:#3a5ce0}.team-btn-save:disabled{cursor:not-allowed;opacity:.6}.team-form-error{background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;color:#ef4444;font-size:13px;margin-bottom:14px;padding:10px 14px}.team-confirm-modal{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000002e;max-width:380px;padding:28px;text-align:center;width:100%}.team-confirm-icon{font-size:40px;margin-bottom:12px}.team-confirm-title{color:#1e293b;font-size:17px;font-weight:700;margin-bottom:8px}.team-confirm-msg{color:#64748b;font-size:13px;line-height:1.5;margin-bottom:22px}.team-confirm-btns{display:flex;gap:10px;justify-content:center}.team-confirm-cancel{background:#fff;border:1px solid #e8eaf0;border-radius:9px;color:#64748b;cursor:pointer;font-size:14px;padding:10px 20px}.team-confirm-delete{background:#ef4444}.team-confirm-delete,.team-confirm-warn{border:none;border-radius:9px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px}.team-confirm-warn{background:#f59e0b}.team-toast{animation:toast-in .2s ease;background:#1e293b;border-radius:10px;bottom:28px;box-shadow:0 8px 24px #0003;color:#fff;font-size:13px;font-weight:500;padding:12px 20px;position:fixed;right:28px;z-index:2000}.discount-page{background:#f5f6fa;min-height:100%;padding:32px}.discount-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:24px}.discount-title{color:#202224;font-size:26px;font-weight:700;margin:0}.discount-subtitle{color:#94a3b8;font-size:14px;margin-top:4px}.discount-create-btn{align-items:center;background:var(--color-primary);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:background .15s,box-shadow .15s;white-space:nowrap}.discount-create-btn:hover{background:#3a5ce0;box-shadow:0 4px 12px #4c6fff59}.discount-stats-strip{grid-gap:14px;display:grid;gap:14px;grid-template-columns:repeat(5,1fr);margin-bottom:24px}@media (max-width:1100px){.discount-stats-strip{grid-template-columns:repeat(3,1fr)}}@media (max-width:700px){.discount-stats-strip{grid-template-columns:repeat(2,1fr)}}.discount-stat-card{align-items:center;background:#fff;border-left:4px solid #0000;border-radius:14px;box-shadow:0 1px 4px #0000000f;display:flex;gap:14px;padding:18px 20px}.discount-stat-icon{align-items:center;border-radius:11px;display:flex;flex-shrink:0;font-size:19px;height:42px;justify-content:center;width:42px}.discount-stat-label{color:#94a3b8;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.discount-stat-value{color:#1e293b;font-size:22px;font-weight:800;line-height:1.2}.discount-filters{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.discount-search-wrap{flex:1 1;min-width:200px;position:relative}.discount-search-icon{color:#94a3b8;font-size:14px;left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.discount-search{background:#fff;border:1px solid #e8eaf0;border-radius:10px;box-sizing:border-box;font-size:14px;outline:none;padding:10px 14px 10px 36px;transition:border-color .2s,box-shadow .2s;width:100%}.discount-search:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4c6fff1a}.discount-filter-select{color:#374151;cursor:pointer;font-size:13px;outline:none;padding:10px 14px}.discount-filter-select,.discount-status-tabs{background:#fff;border:1px solid #e8eaf0;border-radius:10px}.discount-status-tabs{display:flex;gap:2px;padding:4px}.discount-status-tab{background:none;border:none;border-radius:7px;color:#64748b;cursor:pointer;font-size:13px;font-weight:500;padding:7px 14px;transition:all .15s;white-space:nowrap}.discount-status-tab.active{background:var(--color-primary);box-shadow:0 2px 6px #4c6fff40;color:#fff}.discount-status-tab:not(.active):hover{background:#f1f5f9;color:#374151}.discount-table-wrap{background:#fff;border-radius:16px;box-shadow:0 1px 4px #0000000f;margin-bottom:24px;overflow:hidden}.discount-table{border-collapse:collapse;width:100%}.discount-table th{background:#f8f9fc;border-bottom:1px solid #f0f2f8;color:#94a3b8;font-size:11px;font-weight:700;letter-spacing:.06em;padding:12px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.discount-table td{border-bottom:1px solid #f8f9fc;color:#374151;font-size:13px;padding:14px 16px;vertical-align:middle}.discount-table tbody tr:last-child td{border-bottom:none}.discount-table tbody tr:hover td{background:#fafbff}.discount-code-chip{align-items:center;background:#f0f4ff;border:1px dashed #c7d2fe;border-radius:8px;color:var(--color-primary);cursor:pointer;display:inline-flex;font-family:monospace;font-size:13px;font-weight:700;gap:6px;letter-spacing:.05em;padding:5px 10px;transition:background .15s}.discount-code-chip:hover{background:#e0e7ff}.discount-code-copy{font-size:12px;opacity:.6}.discount-type-badge{border-radius:20px;display:inline-block;font-size:11px;font-weight:700;letter-spacing:.03em;padding:3px 10px;text-transform:uppercase}.discount-type-badge.percentage{background:#f0fdf4;color:#16a34a}.discount-type-badge.fixed{background:#fef9c3;color:#b45309}.discount-value{color:#1e293b;font-size:15px;font-weight:800}.discount-scope-badge{background:#f1f5f9;border-radius:20px;color:#64748b;display:inline-block;font-size:11px;font-weight:600;padding:3px 9px;text-transform:capitalize}.discount-usage-wrap{min-width:120px}.discount-usage-row{color:#4b5563;display:flex;font-size:11.5px;font-weight:600;justify-content:space-between;letter-spacing:.1px;margin-bottom:6px}.discount-usage-row>span:last-child{color:var(--color-text-muted);font-weight:500}.discount-usage-track{background:#e5e7eb;border-radius:999px;height:8px;overflow:hidden;position:relative}.discount-usage-fill{background:linear-gradient(90deg,var(--color-primary) 0,#fbbf24 100%);border-radius:999px;box-shadow:0 0 8px #f59e0b66;height:100%;min-width:4px;transition:width .6s cubic-bezier(.2,.8,.2,1)}.discount-usage-fill.is-zero{background:#d1d5db;box-shadow:none}.discount-toggle{flex-shrink:0;height:22px;position:relative;width:40px}.discount-toggle input{height:0;opacity:0;width:0}.discount-toggle-slider{background:#d1d5db;border-radius:20px;cursor:pointer;inset:0;position:absolute;transition:background .2s}.discount-toggle-slider:before{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;content:"";height:16px;left:3px;position:absolute;top:3px;transition:transform .2s;width:16px}.discount-toggle input:checked+.discount-toggle-slider{background:var(--color-primary)}.discount-toggle input:checked+.discount-toggle-slider:before{transform:translateX(18px)}.discount-expiry{color:#64748b;font-size:12px;white-space:nowrap}.discount-expiry.expired{color:#ef4444}.discount-expiry.soon{color:#f59e0b}.discount-actions{align-items:center;display:flex;gap:6px}.discount-action-btn{align-items:center;background:#fff;border:1px solid #d0d5dd;border:1px solid var(--color-border-strong,#d0d5dd);border-radius:9px;color:#64748b;cursor:pointer;display:inline-flex;font-size:14px;height:34px;justify-content:center;transition:background-color .15s ease,border-color .15s ease,color .15s ease,transform .15s ease,box-shadow .15s ease;width:34px}.discount-action-btn svg{height:15px;width:15px}.discount-action-btn:hover{background:var(--color-primary-soft);border-color:var(--color-primary);box-shadow:0 2px 6px -2px #f59e0b4d;color:var(--color-primary);transform:translateY(-1px)}.discount-action-btn.danger:hover{background:#fef3f2;border-color:#fda29b;box-shadow:0 2px 6px -2px #b4231840;color:#b42318}.discount-empty{align-items:center;background:#fff;border-radius:16px;box-shadow:0 1px 4px #0000000f;display:flex;flex-direction:column;padding:64px 24px}.discount-empty-icon{font-size:52px;margin-bottom:16px;opacity:.4}.discount-empty-title{color:#475569;font-size:16px;font-weight:600;margin-bottom:6px}.discount-empty-sub{color:#94a3b8;font-size:13px;margin-bottom:20px}.discount-skeleton{animation:disc-shimmer 1.4s infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8 50%,#f0f0f0 75%);background-size:200% 100%;border-radius:6px}@keyframes disc-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.discount-error{background:#fef2f2;border:1px solid #fca5a5;border-radius:10px;color:#ef4444;font-size:14px;margin-bottom:16px;padding:12px 16px}.discount-modal-overlay{align-items:center;background:#0f172a73;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.discount-modal{background:#fff;border-radius:18px;box-shadow:0 20px 60px #0000002e;max-height:90vh;max-width:560px;overflow-y:auto;width:100%}.discount-modal-header{align-items:center;border-bottom:1px solid #f0f2f8;display:flex;justify-content:space-between;padding:22px 24px 18px}.discount-modal-title{color:#1e293b;font-size:17px;font-weight:700}.discount-modal-close{align-items:center;background:#f1f5f9;border:none;border-radius:8px;color:#64748b;cursor:pointer;display:flex;font-size:16px;height:30px;justify-content:center;transition:background .15s;width:30px}.discount-modal-close:hover{background:#e2e8f0}.discount-modal-body{padding:22px 24px}.discount-form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.discount-form-full{grid-column:1/-1}.discount-field{display:flex;flex-direction:column;gap:6px}.discount-label{color:#475569;font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.discount-input,.discount-select,.discount-textarea{background:#fff;border:1px solid #e8eaf0;border-radius:9px;color:#1e293b;font-size:14px;outline:none;padding:10px 12px;transition:border-color .2s,box-shadow .2s}.discount-input:focus,.discount-select:focus,.discount-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4c6fff1a}.discount-textarea{min-height:70px;resize:vertical}.discount-hint{color:#94a3b8;font-size:11px}.discount-type-toggle{border:1px solid #e8eaf0;border-radius:9px;display:flex;overflow:hidden}.discount-type-option{background:none;border:none;color:#64748b;cursor:pointer;flex:1 1;font-size:13px;font-weight:500;padding:10px;transition:all .15s}.discount-type-option.active{background:var(--color-primary);color:#fff;font-weight:700}.discount-modal-footer{border-top:1px solid #f0f2f8;display:flex;gap:10px;justify-content:flex-end;padding:16px 24px 22px}.discount-btn-cancel{background:#fff;border:1px solid #e8eaf0;border-radius:9px;color:#64748b;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:background .15s}.discount-btn-cancel:hover{background:#f8f9fc}.discount-btn-save{background:var(--color-primary);border:none;border-radius:9px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:background .15s}.discount-btn-save:hover{background:#3a5ce0}.discount-btn-save:disabled{cursor:not-allowed;opacity:.6}.discount-pagination{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 4px #0000000f;display:flex;justify-content:space-between;padding:14px 18px}.discount-pagination-info{color:#94a3b8;font-size:13px}.discount-pagination-controls{align-items:center;display:flex;gap:4px}.discount-page-btn{align-items:center;background:#fff;border:1px solid #e8eaf0;border-radius:8px;color:#475569;cursor:pointer;display:flex;font-size:13px;font-weight:500;height:34px;justify-content:center;min-width:34px;padding:0 8px;transition:all .15s}.discount-page-btn.current,.discount-page-btn:hover:not(:disabled){background:var(--color-primary);border-color:var(--color-primary);color:#fff}.discount-page-btn.current{font-weight:700}.discount-page-btn:disabled{cursor:not-allowed;opacity:.35}.discount-toast{animation:toast-in .2s ease;background:#1e293b;border-radius:10px;bottom:28px;box-shadow:0 8px 24px #0003;color:#fff;font-size:13px;font-weight:500;padding:12px 20px;position:fixed;right:28px;z-index:2000}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.calendar-page{background:#f8f9fb;display:flex;height:calc(100vh - 64px);overflow:hidden}.cal-sidebar{background:#fff;border-right:1px solid #e8eaf0;display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;padding-bottom:24px;width:260px}.cal-sidebar-section{padding:20px 16px 8px}.cal-sidebar-section-title{color:#9ca3af;font-size:11px;font-weight:700;letter-spacing:.08em;margin-bottom:12px;text-transform:uppercase}.mini-cal{-webkit-user-select:none;user-select:none}.mini-cal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:10px}.mini-cal-month{color:#1e293b;font-size:13px;font-weight:600}.mini-cal-nav{background:none;border:none;border-radius:4px;color:#64748b;cursor:pointer;font-size:14px;line-height:1;padding:2px 6px}.mini-cal-nav:hover{background:#f1f5f9}.mini-cal-grid{grid-gap:2px;display:grid;gap:2px;grid-template-columns:repeat(7,1fr);text-align:center}.mini-cal-dow{color:#94a3b8;font-size:10px;font-weight:600;padding:3px 0}.mini-cal-day{align-items:center;aspect-ratio:1;border-radius:50%;color:#374151;cursor:pointer;display:flex;font-size:12px;justify-content:center;padding:4px;transition:background .15s}.mini-cal-day:hover{background:#f1f5f9}.mini-cal-day.other-month{color:#cbd5e1}.mini-cal-day.today{background:var(--color-primary);color:#fff;font-weight:700}.mini-cal-day.selected{background:#e0e7ff;color:var(--color-primary);font-weight:600}.mini-cal-day.has-events:after{background:var(--color-primary);border-radius:50%;content:"";display:block;height:4px;margin:1px auto 0;width:4px}.category-list{display:flex;flex-direction:column;gap:4px;margin-bottom:10px}.category-item{align-items:center;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:13px;gap:8px;padding:7px 10px;transition:background .15s}.category-item:hover{background:#f8f9fb}.category-item.active{background:#f0f4ff}.category-dot{border-radius:50%;flex-shrink:0;height:10px;width:10px}.category-name{flex:1 1;font-weight:500}.category-actions{display:none;gap:4px}.category-item:hover .category-actions{display:flex}.cat-action-btn{background:none;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;font-size:12px;line-height:1;padding:2px}.cat-action-btn:hover{background:#e0e7ff;color:var(--color-primary)}.cat-action-btn.delete:hover{background:#fee2e2;color:#ef4444}.btn-add-category{align-items:center;background:none;border:1.5px dashed #d1d5db;border-radius:8px;color:#9ca3af;cursor:pointer;display:flex;font-size:13px;gap:6px;padding:8px 10px;transition:all .15s;width:100%}.btn-add-category:hover{background:#f0f4ff;border-color:var(--color-primary);color:var(--color-primary)}.cal-main{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.cal-toolbar{background:#fff;border-bottom:1px solid #e8eaf0;gap:12px;justify-content:space-between;padding:14px 24px}.cal-toolbar,.cal-toolbar-left{align-items:center;display:flex}.cal-toolbar-left{gap:8px}.cal-toolbar-title{color:#1e293b;font-size:18px;font-weight:700;min-width:200px}.btn-nav{align-items:center;background:#f1f5f9;border:none;border-radius:8px;color:#475569;cursor:pointer;display:flex;font-size:16px;height:32px;justify-content:center;transition:all .15s;width:32px}.btn-nav:hover{background:#e2e8f0;color:#1e293b}.btn-today{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#374151;cursor:pointer;font-size:13px;font-weight:500;padding:6px 14px;transition:all .15s}.btn-today:hover{background:#f8f9fb;border-color:var(--color-primary);color:var(--color-primary)}.cal-toolbar-right{align-items:center;display:flex;gap:8px}.view-toggle{background:#f1f5f9;border-radius:8px;display:flex;padding:3px}.view-btn{background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;font-size:13px;font-weight:500;padding:5px 14px;transition:all .15s}.view-btn.active{background:#fff;box-shadow:0 1px 3px #0000001a;color:var(--color-primary)}.btn-new-event{align-items:center;background:var(--color-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:background .15s}.btn-new-event:hover{background:#3b5bdb}.cal-month{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.cal-month-header{background:#fff;border-bottom:1px solid #e8eaf0;display:grid;grid-template-columns:repeat(7,1fr)}.cal-dow{color:#64748b;font-size:12px;font-weight:600;letter-spacing:.04em;padding:10px 12px;text-align:center;text-transform:uppercase}.cal-grid{display:grid;flex:1 1;grid-template-columns:repeat(7,1fr);grid-template-rows:repeat(6,1fr);overflow:hidden}.cal-cell{border-bottom:1px solid #e8eaf0;border-right:1px solid #e8eaf0;cursor:pointer;display:flex;flex-direction:column;min-height:0;overflow:hidden;padding:6px;transition:background .1s}.cal-cell:hover{background:#f8f9fb}.cal-cell.other-month{background:#fcfcfd}.cal-cell.other-month .cal-day-num{color:#cbd5e1}.cal-cell.today .cal-day-num{background:var(--color-primary);color:#fff}.cal-cell.selected{background:#f0f4ff}.cal-day-num{align-items:center;border-radius:50%;color:#374151;display:flex;flex-shrink:0;font-size:13px;font-weight:600;height:24px;justify-content:center;margin-bottom:4px;width:24px}.cal-events{flex:1 1;flex-direction:column;gap:2px;min-height:0}.cal-event-pill,.cal-events{display:flex;overflow:hidden}.cal-event-pill{align-items:center;border-radius:4px;color:#fff;cursor:pointer;flex-shrink:0;font-size:11px;font-weight:500;gap:4px;padding:2px 6px;text-overflow:ellipsis;transition:opacity .15s;white-space:nowrap}.cal-event-pill:hover{opacity:.85}.cal-event-pin{flex-shrink:0;font-size:9px}.cal-event-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cal-more{border-radius:4px;color:#64748b;cursor:pointer;font-size:11px;padding:1px 4px}.cal-more:hover{background:#e2e8f0}.cal-week{display:flex;flex:1 1;flex-direction:column;overflow:hidden}.cal-week-header{background:#fff;border-bottom:1px solid #e8eaf0;display:grid;grid-template-columns:60px repeat(7,1fr)}.week-day-header,.week-time-gutter{border-right:1px solid #e8eaf0}.week-day-header{cursor:pointer;padding:10px 8px;text-align:center}.week-day-label{color:#94a3b8;font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.week-day-num{align-items:center;border-radius:50%;color:#374151;display:flex;font-size:20px;font-weight:700;height:36px;justify-content:center;line-height:1.2;margin:2px auto 0;width:36px}.week-day-header.today .week-day-num{background:var(--color-primary);color:#fff}.cal-week-body{display:grid;flex:1 1;grid-template-columns:60px repeat(7,1fr);overflow-y:auto}.week-time-col{border-right:1px solid #e8eaf0}.week-time-slot{align-items:flex-start;border-bottom:1px solid #f1f5f9;display:flex;height:56px;justify-content:flex-end;padding-right:8px}.week-time-label{color:#94a3b8;font-size:10px;margin-top:-6px;white-space:nowrap}.week-day-col{border-right:1px solid #e8eaf0;cursor:pointer;position:relative}.week-day-col:hover{background:#f8f9fb}.week-day-col.today{background:#fafbff}.week-hour-slot{border-bottom:1px solid #f1f5f9;height:56px}.week-events-overlay{inset:0;pointer-events:none;position:absolute}.week-event-block{border-radius:6px;color:#fff;cursor:pointer;font-size:11px;font-weight:500;left:4px;overflow:hidden;padding:4px 6px;pointer-events:all;position:absolute;right:4px;transition:opacity .15s}.week-event-block:hover{opacity:.85}.modal-overlay{align-items:center;animation:fadeIn .15s ease;background:#0006;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-card{animation:slideUp .2s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;max-height:90vh;max-width:480px;overflow-y:auto;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;padding:20px 24px 16px}.modal-title{color:#1e293b;font-size:16px;font-weight:700}.modal-close{background:none;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;font-size:20px;line-height:1;padding:4px;transition:all .15s}.modal-close:hover{background:#f1f5f9;color:#374151}.modal-body{padding:20px 24px}.form-group{margin-bottom:16px}.form-label{color:#374151;display:block;font-size:13px;font-weight:600;margin-bottom:6px}.form-input,.form-select,.form-textarea{background:#fff;border:1.5px solid #e2e8f0;border-radius:8px;box-sizing:border-box;color:#1e293b;font-size:14px;outline:none;padding:9px 12px;transition:border-color .15s;width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4c6fff1a}.form-textarea{min-height:80px;resize:vertical}.form-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.color-picker{display:flex;flex-wrap:wrap;gap:8px}.color-swatch{border:2.5px solid #0000;border-radius:6px;cursor:pointer;height:28px;transition:transform .1s;width:28px}.color-swatch:hover{transform:scale(1.15)}.color-swatch.selected{border-color:#1e293b;transform:scale(1.15)}.form-checkbox-row{align-items:center;cursor:pointer;display:flex;gap:8px}.form-checkbox{accent-color:var(--color-primary);cursor:pointer;height:16px;width:16px}.form-checkbox-label{color:#374151;font-size:14px}.modal-footer{align-items:center;border-top:1px solid #f1f5f9;justify-content:space-between;padding:16px 24px 20px}.modal-footer,.modal-footer-right{display:flex;gap:8px}.btn-cancel{background:#fff;border:1px solid #e2e8f0;border-radius:8px;color:#374151;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .15s}.btn-cancel:hover{background:#f8f9fb}.btn-save{background:var(--color-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 20px;transition:background .15s}.btn-save:hover{background:#3b5bdb}.btn-save:disabled{cursor:not-allowed;opacity:.6}.btn-delete-event{background:#fee2e2;border:none;border-radius:8px;color:#ef4444;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:background .15s}.btn-delete-event:hover{background:#fecaca}.event-detail-panel{animation:slideUp .2s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;left:50%;overflow:hidden;position:fixed;top:50%;transform:translate(-50%,-50%);width:360px;z-index:1000}.event-detail-color-bar{height:6px}.event-detail-body{padding:20px}.event-detail-title{color:#1e293b;font-size:16px;font-weight:700;margin-bottom:12px}.event-detail-row{align-items:flex-start;color:#64748b;display:flex;font-size:13px;gap:10px;margin-bottom:8px}.event-detail-icon{flex-shrink:0;margin-top:1px}.event-detail-actions{border-top:1px solid #f1f5f9;display:flex;gap:8px;margin-top:16px;padding-top:16px}.btn-edit-event{background:#f0f4ff;border:none;border-radius:8px;color:var(--color-primary);cursor:pointer;flex:1 1;font-size:13px;font-weight:600;padding:8px;transition:background .15s}.btn-edit-event:hover{background:#e0e7ff}.cal-loading{align-items:center;color:#64748b;display:flex;flex:1 1;font-size:15px;gap:10px;justify-content:center}.cal-spinner{animation:spin .7s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top:3px solid var(--color-primary);height:24px;width:24px}@keyframes spin{to{transform:rotate(1turn)}}.cal-error{align-items:center;color:#ef4444;display:flex;flex:1 1;flex-direction:column;font-size:14px;gap:8px;justify-content:center}.btn-retry{background:#fee2e2;border:none;border-radius:8px;color:#ef4444;cursor:pointer;font-size:13px;padding:6px 14px}.modal-card.small{max-width:380px}.cal-pinned-band{align-items:center;background:#fff;border-bottom:1px solid #e8eaf0;display:flex;flex-wrap:wrap;gap:8px;padding:8px 24px}.cal-pinned-label{color:#9ca3af;flex-shrink:0;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.cal-pinned-pill{align-items:center;border-radius:20px;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:5px;padding:3px 10px;transition:opacity .15s}.cal-pinned-pill:hover{opacity:.85}.App{background-color:#fff;display:flex;height:100vh;width:100%}.page-content{color:#202224;font-size:24px;font-weight:600;padding:32px}
/*# sourceMappingURL=main.99e6e61a.css.map*/