@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary: #ffffff;--bg-secondary: #f8fafb;--bg-glass: rgba(255, 255, 255, .75);--bg-glass-hover: rgba(255, 255, 255, .9);--border-glass: rgba(0, 0, 0, .08);--border-glow: rgba(22, 163, 74, .3);--accent: #16a34a;--accent-light: #22c55e;--accent-dark: #15803d;--accent-glow: rgba(22, 163, 74, .12);--accent-glow-strong: rgba(22, 163, 74, .3);--text-primary: #111827;--text-secondary: #6b7280;--text-muted: #9ca3af;--danger: #ef4444;--success: #16a34a;--warning: #f59e0b;--info: #3b82f6;--purple: #8b5cf6;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-md: 0 4px 16px rgba(0, 0, 0, .06);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .08);--shadow-glow: 0 0 20px rgba(22, 163, 74, .08), 0 4px 16px rgba(0, 0, 0, .06);--shadow-card: 0 1px 3px rgba(0, 0, 0, .06), 0 4px 16px rgba(0, 0, 0, .04);font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6;font-weight:400;color:var(--text-primary);background-color:var(--bg-secondary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box;margin:0;padding:0}body{min-width:320px;min-height:100vh;overflow-x:hidden;background:var(--bg-secondary)}a{color:var(--accent);text-decoration:none;transition:color .2s ease}a:hover{color:var(--accent-dark)}.glass{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-glass);box-shadow:var(--shadow-card)}.glass:hover{background:var(--bg-glass-hover);border-color:var(--border-glow);box-shadow:var(--shadow-glow)}.glow-border{position:relative;transition:box-shadow .3s ease}.glow-border:hover{box-shadow:var(--shadow-glow)}.loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.1rem;color:var(--text-secondary);gap:.75rem}.unauthorized{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;color:var(--danger);gap:.5rem}.unauthorized p{color:var(--text-secondary)}.logo-text{font-size:1.25rem;font-weight:800;letter-spacing:-.03em}.logo-up{color:var(--text-primary)}.logo-green{color:var(--accent)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#0000001f;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#0003}[data-theme=dark]{--bg-primary: #111111;--bg-secondary: #0a0a0a;--bg-glass: rgba(20, 20, 20, .75);--bg-glass-hover: rgba(30, 30, 30, .9);--border-glass: rgba(255, 255, 255, .08);--border-glow: rgba(22, 163, 74, .4);--accent-glow: rgba(22, 163, 74, .15);--accent-glow-strong: rgba(22, 163, 74, .35);--text-primary: #f3f4f6;--text-secondary: #9ca3af;--text-muted: #6b7280;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px rgba(22, 163, 74, .12), 0 4px 16px rgba(0, 0, 0, .3);--shadow-card: 0 1px 3px rgba(0, 0, 0, .3), 0 4px 16px rgba(0, 0, 0, .2);color-scheme:dark}[data-theme=dark] .logo-up{color:#f3f4f6}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#ffffff1f}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#fff3}:root{--toastify-color-light: #fff;--toastify-color-dark: #121212;--toastify-color-info: #3498db;--toastify-color-success: #07bc0c;--toastify-color-warning: #f1c40f;--toastify-color-error: hsl(6, 78%, 57%);--toastify-color-transparent: rgba(255, 255, 255, .7);--toastify-icon-color-info: var(--toastify-color-info);--toastify-icon-color-success: var(--toastify-color-success);--toastify-icon-color-warning: var(--toastify-color-warning);--toastify-icon-color-error: var(--toastify-color-error);--toastify-container-width: fit-content;--toastify-toast-width: 320px;--toastify-toast-offset: 16px;--toastify-toast-top: max(var(--toastify-toast-offset), env(safe-area-inset-top));--toastify-toast-right: max(var(--toastify-toast-offset), env(safe-area-inset-right));--toastify-toast-left: max(var(--toastify-toast-offset), env(safe-area-inset-left));--toastify-toast-bottom: max(var(--toastify-toast-offset), env(safe-area-inset-bottom));--toastify-toast-background: #fff;--toastify-toast-padding: 14px;--toastify-toast-min-height: 64px;--toastify-toast-max-height: 800px;--toastify-toast-bd-radius: 6px;--toastify-toast-shadow: 0px 4px 12px rgba(0, 0, 0, .1);--toastify-font-family: sans-serif;--toastify-z-index: 9999;--toastify-text-color-light: #757575;--toastify-text-color-dark: #fff;--toastify-text-color-info: #fff;--toastify-text-color-success: #fff;--toastify-text-color-warning: #fff;--toastify-text-color-error: #fff;--toastify-spinner-color: #616161;--toastify-spinner-color-empty-area: #e0e0e0;--toastify-color-progress-light: linear-gradient(to right, #4cd964, #5ac8fa, #007aff, #34aadc, #5856d6, #ff2d55);--toastify-color-progress-dark: #bb86fc;--toastify-color-progress-info: var(--toastify-color-info);--toastify-color-progress-success: var(--toastify-color-success);--toastify-color-progress-warning: var(--toastify-color-warning);--toastify-color-progress-error: var(--toastify-color-error);--toastify-color-progress-bgo: .2}.Toastify__toast-container{z-index:var(--toastify-z-index);-webkit-transform:translate3d(0,0,var(--toastify-z-index));position:fixed;width:var(--toastify-container-width);box-sizing:border-box;color:#fff;display:flex;flex-direction:column}.Toastify__toast-container--top-left{top:var(--toastify-toast-top);left:var(--toastify-toast-left)}.Toastify__toast-container--top-center{top:var(--toastify-toast-top);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--top-right{top:var(--toastify-toast-top);right:var(--toastify-toast-right);align-items:end}.Toastify__toast-container--bottom-left{bottom:var(--toastify-toast-bottom);left:var(--toastify-toast-left)}.Toastify__toast-container--bottom-center{bottom:var(--toastify-toast-bottom);left:50%;transform:translate(-50%);align-items:center}.Toastify__toast-container--bottom-right{bottom:var(--toastify-toast-bottom);right:var(--toastify-toast-right);align-items:end}.Toastify__toast{--y: 0;position:relative;touch-action:none;width:var(--toastify-toast-width);min-height:var(--toastify-toast-min-height);box-sizing:border-box;margin-bottom:1rem;padding:var(--toastify-toast-padding);border-radius:var(--toastify-toast-bd-radius);box-shadow:var(--toastify-toast-shadow);max-height:var(--toastify-toast-max-height);font-family:var(--toastify-font-family);z-index:0;display:flex;flex:1 auto;align-items:center;word-break:break-word}@media only screen and (max-width:480px){.Toastify__toast-container{width:100vw;left:env(safe-area-inset-left);margin:0}.Toastify__toast-container--top-left,.Toastify__toast-container--top-center,.Toastify__toast-container--top-right{top:env(safe-area-inset-top);transform:translate(0)}.Toastify__toast-container--bottom-left,.Toastify__toast-container--bottom-center,.Toastify__toast-container--bottom-right{bottom:env(safe-area-inset-bottom);transform:translate(0)}.Toastify__toast-container--rtl{right:env(safe-area-inset-right);left:initial}.Toastify__toast{--toastify-toast-width: 100%;margin-bottom:0;border-radius:0}}.Toastify__toast-container[data-stacked=true]{width:var(--toastify-toast-width)}.Toastify__toast--stacked{position:absolute;width:100%;transform:translate3d(0,var(--y),0) scale(var(--s));transition:transform .3s}.Toastify__toast--stacked[data-collapsed] .Toastify__toast-body,.Toastify__toast--stacked[data-collapsed] .Toastify__close-button{transition:opacity .1s}.Toastify__toast--stacked[data-collapsed=false]{overflow:visible}.Toastify__toast--stacked[data-collapsed=true]:not(:last-child)>*{opacity:0}.Toastify__toast--stacked:after{content:"";position:absolute;left:0;right:0;height:calc(var(--g) * 1px);bottom:100%}.Toastify__toast--stacked[data-pos=top]{top:0}.Toastify__toast--stacked[data-pos=bot]{bottom:0}.Toastify__toast--stacked[data-pos=bot].Toastify__toast--stacked:before{transform-origin:top}.Toastify__toast--stacked[data-pos=top].Toastify__toast--stacked:before{transform-origin:bottom}.Toastify__toast--stacked:before{content:"";position:absolute;left:0;right:0;bottom:0;height:100%;transform:scaleY(3);z-index:-1}.Toastify__toast--rtl{direction:rtl}.Toastify__toast--close-on-click{cursor:pointer}.Toastify__toast-icon{margin-inline-end:10px;width:22px;flex-shrink:0;display:flex}.Toastify--animate{animation-fill-mode:both;animation-duration:.5s}.Toastify--animate-icon{animation-fill-mode:both;animation-duration:.3s}.Toastify__toast-theme--dark{background:var(--toastify-color-dark);color:var(--toastify-text-color-dark)}.Toastify__toast-theme--light,.Toastify__toast-theme--colored.Toastify__toast--default{background:var(--toastify-color-light);color:var(--toastify-text-color-light)}.Toastify__toast-theme--colored.Toastify__toast--info{color:var(--toastify-text-color-info);background:var(--toastify-color-info)}.Toastify__toast-theme--colored.Toastify__toast--success{color:var(--toastify-text-color-success);background:var(--toastify-color-success)}.Toastify__toast-theme--colored.Toastify__toast--warning{color:var(--toastify-text-color-warning);background:var(--toastify-color-warning)}.Toastify__toast-theme--colored.Toastify__toast--error{color:var(--toastify-text-color-error);background:var(--toastify-color-error)}.Toastify__progress-bar-theme--light{background:var(--toastify-color-progress-light)}.Toastify__progress-bar-theme--dark{background:var(--toastify-color-progress-dark)}.Toastify__progress-bar--info{background:var(--toastify-color-progress-info)}.Toastify__progress-bar--success{background:var(--toastify-color-progress-success)}.Toastify__progress-bar--warning{background:var(--toastify-color-progress-warning)}.Toastify__progress-bar--error{background:var(--toastify-color-progress-error)}.Toastify__progress-bar-theme--colored.Toastify__progress-bar--info,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--success,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--warning,.Toastify__progress-bar-theme--colored.Toastify__progress-bar--error{background:var(--toastify-color-transparent)}.Toastify__close-button{color:#fff;position:absolute;top:6px;right:6px;background:transparent;outline:none;border:none;padding:0;cursor:pointer;opacity:.7;transition:.3s ease;z-index:1}.Toastify__toast--rtl .Toastify__close-button{left:6px;right:unset}.Toastify__close-button--light{color:#000;opacity:.3}.Toastify__close-button>svg{fill:currentColor;height:16px;width:14px}.Toastify__close-button:hover,.Toastify__close-button:focus{opacity:1}@keyframes Toastify__trackProgress{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.Toastify__progress-bar{position:absolute;bottom:0;left:0;width:100%;height:100%;z-index:1;opacity:.7;transform-origin:left}.Toastify__progress-bar--animated{animation:Toastify__trackProgress linear 1 forwards}.Toastify__progress-bar--controlled{transition:transform .2s}.Toastify__progress-bar--rtl{right:0;left:initial;transform-origin:right;border-bottom-left-radius:initial}.Toastify__progress-bar--wrp{position:absolute;overflow:hidden;bottom:0;left:0;width:100%;height:5px;border-bottom-left-radius:var(--toastify-toast-bd-radius);border-bottom-right-radius:var(--toastify-toast-bd-radius)}.Toastify__progress-bar--wrp[data-hidden=true]{opacity:0}.Toastify__progress-bar--bg{opacity:var(--toastify-color-progress-bgo);width:100%;height:100%}.Toastify__spinner{width:20px;height:20px;box-sizing:border-box;border:2px solid;border-radius:100%;border-color:var(--toastify-spinner-color-empty-area);border-right-color:var(--toastify-spinner-color);animation:Toastify__spin .65s linear infinite}@keyframes Toastify__bounceInRight{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(3000px,0,0)}60%{opacity:1;transform:translate3d(-25px,0,0)}75%{transform:translate3d(10px,0,0)}90%{transform:translate3d(-5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutRight{20%{opacity:1;transform:translate3d(-20px,var(--y),0)}to{opacity:0;transform:translate3d(2000px,var(--y),0)}}@keyframes Toastify__bounceInLeft{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(-3000px,0,0)}60%{opacity:1;transform:translate3d(25px,0,0)}75%{transform:translate3d(-10px,0,0)}90%{transform:translate3d(5px,0,0)}to{transform:none}}@keyframes Toastify__bounceOutLeft{20%{opacity:1;transform:translate3d(20px,var(--y),0)}to{opacity:0;transform:translate3d(-2000px,var(--y),0)}}@keyframes Toastify__bounceInUp{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,3000px,0)}60%{opacity:1;transform:translate3d(0,-20px,0)}75%{transform:translate3d(0,10px,0)}90%{transform:translate3d(0,-5px,0)}to{transform:translateZ(0)}}@keyframes Toastify__bounceOutUp{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,-2000px,0)}}@keyframes Toastify__bounceInDown{0%,60%,75%,90%,to{animation-timing-function:cubic-bezier(.215,.61,.355,1)}0%{opacity:0;transform:translate3d(0,-3000px,0)}60%{opacity:1;transform:translate3d(0,25px,0)}75%{transform:translate3d(0,-10px,0)}90%{transform:translate3d(0,5px,0)}to{transform:none}}@keyframes Toastify__bounceOutDown{20%{transform:translate3d(0,calc(var(--y) - 10px),0)}40%,45%{opacity:1;transform:translate3d(0,calc(var(--y) + 20px),0)}to{opacity:0;transform:translate3d(0,2000px,0)}}.Toastify__bounce-enter--top-left,.Toastify__bounce-enter--bottom-left{animation-name:Toastify__bounceInLeft}.Toastify__bounce-enter--top-right,.Toastify__bounce-enter--bottom-right{animation-name:Toastify__bounceInRight}.Toastify__bounce-enter--top-center{animation-name:Toastify__bounceInDown}.Toastify__bounce-enter--bottom-center{animation-name:Toastify__bounceInUp}.Toastify__bounce-exit--top-left,.Toastify__bounce-exit--bottom-left{animation-name:Toastify__bounceOutLeft}.Toastify__bounce-exit--top-right,.Toastify__bounce-exit--bottom-right{animation-name:Toastify__bounceOutRight}.Toastify__bounce-exit--top-center{animation-name:Toastify__bounceOutUp}.Toastify__bounce-exit--bottom-center{animation-name:Toastify__bounceOutDown}@keyframes Toastify__zoomIn{0%{opacity:0;transform:scale3d(.3,.3,.3)}50%{opacity:1}}@keyframes Toastify__zoomOut{0%{opacity:1}50%{opacity:0;transform:translate3d(0,var(--y),0) scale3d(.3,.3,.3)}to{opacity:0}}.Toastify__zoom-enter{animation-name:Toastify__zoomIn}.Toastify__zoom-exit{animation-name:Toastify__zoomOut}@keyframes Toastify__flipIn{0%{transform:perspective(400px) rotateX(90deg);animation-timing-function:ease-in;opacity:0}40%{transform:perspective(400px) rotateX(-20deg);animation-timing-function:ease-in}60%{transform:perspective(400px) rotateX(10deg);opacity:1}80%{transform:perspective(400px) rotateX(-5deg)}to{transform:perspective(400px)}}@keyframes Toastify__flipOut{0%{transform:translate3d(0,var(--y),0) perspective(400px)}30%{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(-20deg);opacity:1}to{transform:translate3d(0,var(--y),0) perspective(400px) rotateX(90deg);opacity:0}}.Toastify__flip-enter{animation-name:Toastify__flipIn}.Toastify__flip-exit{animation-name:Toastify__flipOut}@keyframes Toastify__slideInRight{0%{transform:translate3d(110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInLeft{0%{transform:translate3d(-110%,0,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInUp{0%{transform:translate3d(0,110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideInDown{0%{transform:translate3d(0,-110%,0);visibility:visible}to{transform:translate3d(0,var(--y),0)}}@keyframes Toastify__slideOutRight{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(110%,var(--y),0)}}@keyframes Toastify__slideOutLeft{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(-110%,var(--y),0)}}@keyframes Toastify__slideOutDown{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,500px,0)}}@keyframes Toastify__slideOutUp{0%{transform:translate3d(0,var(--y),0)}to{visibility:hidden;transform:translate3d(0,-500px,0)}}.Toastify__slide-enter--top-left,.Toastify__slide-enter--bottom-left{animation-name:Toastify__slideInLeft}.Toastify__slide-enter--top-right,.Toastify__slide-enter--bottom-right{animation-name:Toastify__slideInRight}.Toastify__slide-enter--top-center{animation-name:Toastify__slideInDown}.Toastify__slide-enter--bottom-center{animation-name:Toastify__slideInUp}.Toastify__slide-exit--top-left,.Toastify__slide-exit--bottom-left{animation-name:Toastify__slideOutLeft;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-right,.Toastify__slide-exit--bottom-right{animation-name:Toastify__slideOutRight;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--top-center{animation-name:Toastify__slideOutUp;animation-timing-function:ease-in;animation-duration:.3s}.Toastify__slide-exit--bottom-center{animation-name:Toastify__slideOutDown;animation-timing-function:ease-in;animation-duration:.3s}@keyframes Toastify__spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.navbar{position:sticky;top:0;z-index:100;background:#ffffffd9;backdrop-filter:blur(24px) saturate(1.4);-webkit-backdrop-filter:blur(24px) saturate(1.4);border-bottom:1px solid rgba(0,0,0,.06);box-shadow:0 1px 3px #0000000a}.navbar-inner{display:flex;align-items:center;justify-content:space-between;max-width:1280px;margin:0 auto;padding:0 1.5rem;height:64px}.navbar-brand{display:flex;align-items:center;text-decoration:none}.navbar-actions{display:flex;align-items:center;gap:.75rem}.navbar-divider{width:1px;height:24px;background:#0000001a;flex-shrink:0}.user-info{display:flex;align-items:center;gap:.6rem}.user-avatar{width:34px;height:34px;border-radius:50%;object-fit:cover;box-shadow:0 2px 8px #16a34a40}.user-details{display:flex;flex-direction:column;line-height:1.2}.user-name{font-size:.85rem;font-weight:600;color:var(--text-primary)}.user-role{font-size:.7rem;color:var(--accent);text-transform:uppercase;font-weight:600;letter-spacing:.04em}.btn-logout{display:flex;align-items:center;justify-content:center;width:34px;height:34px;background:#ef44440f;border:1px solid rgba(239,68,68,.15);color:var(--danger);padding:0;border-radius:50%;cursor:pointer;font-family:inherit;transition:all .25s ease}.btn-logout:hover{background:#ef44441a;border-color:#ef44444d;box-shadow:0 2px 12px #ef44441a}.theme-toggle{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid rgba(0,0,0,.08);border-radius:50%;background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;transition:all .25s ease}.theme-toggle:hover{border-color:var(--accent);color:var(--accent);background:#16a34a0a}[data-theme=dark] .navbar{background:#111111d9;border-bottom-color:#ffffff0f;box-shadow:0 1px 3px #0000004d}[data-theme=dark] .navbar-divider{background:#ffffff1a}[data-theme=dark] .theme-toggle{border-color:#ffffff1a;background:#ffffff0d}[data-theme=dark] .btn-logout{background:#ef44441a;border-color:#ef444433}[data-theme=dark] .btn-logout:hover{background:#ef444426;border-color:#ef444459}.sidebar{position:fixed;top:64px;left:0;bottom:0;background:#fff;border-right:1px solid rgba(0,0,0,.06);display:flex;flex-direction:column;z-index:90;overflow:hidden;box-shadow:2px 0 8px #00000008}.sidebar-top{display:flex;align-items:center;justify-content:space-between;padding:1rem;min-height:48px}.sidebar-title{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);white-space:nowrap;overflow:hidden}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid rgba(0,0,0,.08);border-radius:8px;background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;flex-shrink:0;transition:all .2s ease}.sidebar-toggle:hover{border-color:var(--accent);color:var(--accent);background:#16a34a0a}.collapsed .sidebar-top{justify-content:center;padding:1rem .5rem}.sidebar-nav{display:flex;flex-direction:column;gap:2px;padding:0 .5rem;flex:1}.sidebar-link{position:relative;display:flex;align-items:center;gap:.75rem;padding:.65rem .75rem;border-radius:var(--radius-sm);color:var(--text-secondary);text-decoration:none;font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;transition:all .2s ease}.sidebar-link:hover{color:var(--text-primary);background:#00000008}.sidebar-link.active{color:var(--accent);background:#16a34a0f;font-weight:600}.sidebar-icon{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:20px;height:20px;position:relative}.sidebar-badge{position:absolute;top:-6px;right:-8px;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:.6rem;font-weight:700;padding:.1rem .3rem;border-radius:999px;min-width:16px;text-align:center;box-shadow:0 2px 4px #ef444466;animation:pulse-sidebar-badge 2s infinite}@keyframes pulse-sidebar-badge{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.sidebar-label{overflow:hidden;white-space:nowrap;display:flex;align-items:center;gap:.5rem}.sidebar-badge-text{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;font-size:.65rem;font-weight:700;padding:.15rem .4rem;border-radius:999px;min-width:20px;text-align:center;box-shadow:0 2px 4px #ef44444d}.sidebar-static-badge{display:inline-block;margin-left:auto;padding:.12rem .42rem;border-radius:999px;background:linear-gradient(135deg,#16a34a,#0891b2);color:#fff;font-size:.58rem;font-weight:800;letter-spacing:.06em;box-shadow:0 2px 6px #16a34a59}.sidebar-active-bar{position:absolute;left:0;top:25%;bottom:25%;width:3px;border-radius:0 3px 3px 0;background:var(--accent);box-shadow:0 0 8px #16a34a4d}.collapsed .sidebar-link{justify-content:center;padding:.65rem}.collapsed .sidebar-active-bar{left:0}[data-theme=dark] .sidebar{background:#111;border-right-color:#ffffff0f;box-shadow:2px 0 8px #0000004d}[data-theme=dark] .sidebar-toggle{border-color:#ffffff1a;background:#ffffff0d}[data-theme=dark] .sidebar-link:hover{background:#ffffff0a}[data-theme=dark] .sidebar-link.active{background:#16a34a1a}.app-layout{display:flex;min-height:calc(100vh - 64px)}.app-content{flex:1;min-width:0;transition:margin-left .3s ease}.with-sidebar .app-content{margin-left:240px}.spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.spinner-ring{border:3px solid rgba(0,0,0,.06);border-top:3px solid var(--accent);border-radius:50%;box-shadow:0 0 12px #16a34a1a}.spinner-text{color:var(--text-secondary);font-size:.9rem;font-weight:500;letter-spacing:.02em}[data-theme=dark] .spinner-ring{border-color:#ffffff14;border-top-color:var(--accent)}.auth-page{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:1.5rem;position:relative;overflow:hidden;background:linear-gradient(135deg,#f0fdf4,#fff 40%,#eff6ff)}.auth-bg-orb{position:fixed;border-radius:50%;filter:blur(80px);pointer-events:none;animation:orbFloat 8s ease-in-out infinite}.auth-bg-orb-1{width:400px;height:400px;background:radial-gradient(circle,rgba(22,163,74,.1),transparent 70%);top:-10%;right:-5%;animation-delay:0s}.auth-bg-orb-2{width:350px;height:350px;background:radial-gradient(circle,rgba(59,130,246,.08),transparent 70%);bottom:-10%;left:-5%;animation-delay:-4s}@keyframes orbFloat{0%,to{transform:translate(0) scale(1)}33%{transform:translate(20px,-20px) scale(1.05)}66%{transform:translate(-15px,15px) scale(.95)}}.auth-card{width:100%;max-width:440px;padding:2.5rem;border-radius:var(--radius-xl);background:#ffffffd9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(0,0,0,.06);box-shadow:0 8px 40px #0000000f,0 1px 3px #0000000a}.auth-header{text-align:center;margin-bottom:2rem}.auth-logo{display:inline-flex;align-items:center;justify-content:center;margin-bottom:1rem}.auth-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .35rem;letter-spacing:-.02em}.auth-header p{color:var(--text-secondary);font-size:.9rem;margin:0}.input-row{display:flex;gap:.75rem}.input-row .input-group{flex:1}.input-group{margin-bottom:1.25rem}.input-group label{display:block;margin-bottom:.4rem;font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.input-wrapper{display:flex;align-items:center;gap:.6rem;padding:0 .85rem;border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-sm);background:#fff;transition:all .3s ease}.input-wrapper svg{color:var(--text-muted);flex-shrink:0;transition:color .3s ease}.input-wrapper:focus-within{border-color:var(--accent);background:#16a34a05;box-shadow:0 0 0 3px #16a34a14,0 2px 8px #16a34a0f}.input-wrapper:focus-within svg{color:var(--accent)}.input-wrapper input{width:100%;padding:.7rem 0;border:none;background:transparent;color:var(--text-primary);font-size:.925rem;font-family:inherit;outline:none}.input-wrapper input::placeholder{color:var(--text-muted)}.btn-submit{width:100%;padding:.75rem;margin-top:.5rem;border:none;border-radius:var(--radius-sm);background:linear-gradient(135deg,#16a34a,#059669);color:#fff;font-size:.95rem;font-weight:600;font-family:inherit;cursor:pointer;position:relative;overflow:hidden;transition:box-shadow .3s ease}.btn-submit:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.15) 50%,transparent 60%);transform:translate(-100%);transition:transform .6s ease}.btn-submit:hover:not(:disabled):before{transform:translate(100%)}.btn-submit:hover:not(:disabled){box-shadow:0 4px 20px #16a34a4d,0 2px 8px #16a34a26}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;margin-top:1.5rem;font-size:.875rem;color:var(--text-secondary)}.auth-footer a{color:var(--accent);font-weight:600;transition:color .2s ease}.auth-footer a:hover{color:var(--accent-dark)}[data-theme=dark] .auth-page{background:linear-gradient(135deg,#0a1a0f,#0a0a0a 40%,#0a0f1a)}[data-theme=dark] .auth-bg-orb-1{background:radial-gradient(circle,rgba(22,163,74,.15),transparent 70%)}[data-theme=dark] .auth-bg-orb-2{background:radial-gradient(circle,rgba(59,130,246,.1),transparent 70%)}[data-theme=dark] .auth-card{background:#141414d9;border-color:#ffffff14;box-shadow:0 8px 40px #0006,0 1px 3px #0000004d}[data-theme=dark] .input-wrapper{border-color:#ffffff1a;background:#ffffff0a}[data-theme=dark] .input-wrapper:focus-within{background:#16a34a0f}.dashboard{max-width:960px;margin:0 auto;padding:2rem 1.5rem 3rem}.db-welcome{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid rgba(0,0,0,.06)}.db-welcome-text h1{font-size:1.75rem;font-weight:800;letter-spacing:-.03em;margin:0 0 .3rem;color:var(--text-primary);line-height:1.2}.db-highlight{background:linear-gradient(135deg,var(--accent),#059669);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.db-welcome-sub{color:var(--text-secondary);font-size:.95rem;margin:0}.db-role-badge{display:inline-flex;align-items:center;padding:.35rem .9rem;border-radius:20px;font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;flex-shrink:0}.db-role-admin{background:#ef44441a;color:#dc2626;border:1px solid rgba(239,68,68,.2)}.db-role-instructor{background:#f59e0b1a;color:#d97706;border:1px solid rgba(245,158,11,.2)}.db-role-student{background:#22c55e1a;color:#16a34a;border:1px solid rgba(34,197,94,.2)}.db-welcome-actions{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.db-export-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem 1rem;border-radius:20px;border:1px solid #16a34a;background:#16a34a;color:#fff;font-size:.8rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s ease;white-space:nowrap}.db-export-btn:hover:not(:disabled){background:#15803d;border-color:#15803d;box-shadow:0 2px 10px #16a34a4d}.db-export-btn:disabled{opacity:.65;cursor:not-allowed}.db-tabs{display:flex;gap:.25rem;padding:.3rem;border-radius:var(--radius-md);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.db-tab{position:relative;flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem .75rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:500;font-family:inherit;cursor:pointer;transition:color .2s ease;z-index:1}.db-tab:hover{color:var(--text-primary)}.db-tab.active{color:var(--accent);font-weight:600}.db-tab svg{flex-shrink:0}.db-tab-indicator{position:absolute;inset:0;border-radius:var(--radius-sm);background:#16a34a0f;border:1px solid rgba(22,163,74,.15);z-index:-1}.db-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1rem}.db-stats-row-3{grid-template-columns:repeat(3,1fr)}.db-stat-card{display:flex;align-items:center;gap:.9rem;padding:1.15rem 1.1rem;border-radius:var(--radius-md);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);transition:box-shadow .3s ease;cursor:default}.db-stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.db-stat-body{display:flex;flex-direction:column;min-width:0}.db-stat-value{font-size:1.4rem;font-weight:800;letter-spacing:-.03em;line-height:1.2}.db-stat-label{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-top:.1rem}.db-stat-sub{font-size:.72rem;color:var(--text-secondary);margin-top:.15rem}.db-card{padding:1.5rem;border-radius:var(--radius-lg);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);margin-bottom:1rem}.db-card-center{display:flex;flex-direction:column;align-items:center}.db-card-title{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem}.db-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.db-grid-2 .db-card{margin-bottom:0}.db-chart-wrap{width:100%;min-height:200px}.db-chart-tooltip{background:#fffffff5;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(0,0,0,.08);border-radius:10px;padding:.6rem .85rem;box-shadow:0 4px 20px #0000001a;min-width:100px}.tooltip-label{display:block;font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#6b7280;margin-bottom:.35rem}.tooltip-row{display:flex;align-items:center;gap:.4rem;font-size:.82rem;padding:.1rem 0}.tooltip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.tooltip-name{color:#6b7280;flex:1}.tooltip-val{font-weight:700}.ring-container{position:relative;display:flex;align-items:center;justify-content:center;margin:.5rem 0 1rem;--ring-bg: rgba(0, 0, 0, .06)}.ring-svg circle{transition:stroke .4s ease}.ring-label{position:absolute;display:flex;flex-direction:column;align-items:center}.ring-value{font-size:1.5rem;font-weight:800;letter-spacing:-.03em;line-height:1}.ring-sub{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-top:.2rem}.db-ring-stats{display:flex;gap:2.5rem;margin-top:.25rem}.db-ring-stat{display:flex;flex-direction:column;align-items:center;gap:.1rem}.db-ring-stat-val{font-size:1.15rem;font-weight:700;color:var(--text-primary)}.db-ring-stat-lbl{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.db-progress-list{display:flex;flex-direction:column;gap:1rem}.db-progress-row{display:flex;flex-direction:column;gap:.35rem}.db-progress-header{display:flex;justify-content:space-between;align-items:center}.db-progress-label{font-size:.82rem;font-weight:500;color:var(--text-secondary)}.db-progress-count{font-size:.85rem;font-weight:700}.db-progress-track{height:8px;border-radius:4px;background:#0000000d;overflow:hidden}.db-progress-fill{height:100%;border-radius:4px}.db-progress-pct{font-size:.7rem;font-weight:600;color:var(--text-muted)}.db-inactive-note{margin-top:1rem;padding-top:.85rem;border-top:1px solid rgba(0,0,0,.06);font-size:.8rem;color:var(--text-muted)}.db-hw-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.db-hw-grid-3{grid-template-columns:1fr 1fr 1fr}.db-hw-grid-5{grid-template-columns:repeat(5,1fr);gap:.75rem}.db-hw-stat{display:flex;flex-direction:column;align-items:center;padding:1rem .5rem;border-radius:var(--radius-sm);background:#00000005}.db-hw-val{font-size:1.5rem;font-weight:800;letter-spacing:-.02em;line-height:1}.db-hw-lbl{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-top:.35rem}.db-section-title{font-size:.95rem;font-weight:700;color:var(--text-primary);margin:.5rem 0 1rem}.db-actions-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.db-quick-action{display:flex;align-items:center;gap:.85rem;padding:1rem 1.1rem;border-radius:var(--radius-md);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);text-decoration:none;color:inherit;transition:all .25s ease}.db-quick-action:hover{border-color:var(--qa-color, var(--accent));box-shadow:0 4px 20px color-mix(in srgb,var(--qa-color, var(--accent)) 12%,transparent);transform:translateY(-2px)}.qa-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.qa-text{flex:1;display:flex;flex-direction:column;min-width:0}.qa-label{font-size:.88rem;font-weight:600;color:var(--text-primary)}.qa-desc{font-size:.75rem;color:var(--text-muted);margin-top:.1rem}.qa-arrow{color:var(--text-muted);opacity:0;transform:translate(-4px);transition:all .25s ease;flex-shrink:0}.db-quick-action:hover .qa-arrow{opacity:1;transform:translate(0);color:var(--qa-color, var(--accent))}.db-activity-list{display:flex;flex-direction:column}.db-activity-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid rgba(0,0,0,.04)}.db-activity-item:last-child{border-bottom:none;padding-bottom:0}.db-activity-item:first-child{padding-top:0}.db-activity-left{display:flex;flex-direction:column;gap:.15rem;min-width:0}.db-activity-title{font-size:.88rem;font-weight:600;color:var(--text-primary)}.db-activity-meta{font-size:.75rem;color:var(--text-muted)}.status-chip{display:inline-flex;align-items:center;padding:.25rem .65rem;border-radius:6px;font-size:.72rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;flex-shrink:0}.db-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2.5rem 1rem;color:var(--text-muted)}.db-empty-icon{opacity:.25;margin-bottom:.5rem}.db-empty-state p{margin:0;font-size:.85rem}.db-skeleton-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.db-skeleton-card{display:flex;align-items:center;gap:.9rem;padding:1.15rem 1.1rem;border-radius:var(--radius-md);background:#fff;border:1px solid rgba(0,0,0,.06)}.skel-circle{width:44px;height:44px;border-radius:12px;background:linear-gradient(90deg,#0000000a 25%,#00000014,#0000000a 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;flex-shrink:0}.skel-lines{flex:1;display:flex;flex-direction:column;gap:6px}.skel-line{height:10px;border-radius:4px;background:linear-gradient(90deg,#0000000a 25%,#00000014,#0000000a 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}.skel-line.w60{width:60%}.skel-line.w40{width:40%}.db-error-card{display:flex;align-items:center;justify-content:center;gap:1rem;padding:1.5rem;border-radius:var(--radius-lg);background:#fff;border:1px solid rgba(239,68,68,.15);box-shadow:var(--shadow-sm)}.db-error-card p{margin:0;font-size:.9rem;color:var(--text-secondary)}.db-retry-btn{padding:.45rem 1.1rem;border-radius:var(--radius-sm);border:1px solid var(--accent);background:transparent;color:var(--accent);font-size:.82rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s ease}.db-retry-btn:hover{background:var(--accent);color:#fff}.recharts-legend-item-text{color:var(--text-secondary)!important;font-size:.78rem!important}.recharts-default-legend{margin-top:8px!important}@media(max-width:900px){.db-stats-row,.db-skeleton-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:720px){.db-grid-2,.db-actions-grid{grid-template-columns:1fr}}@media(max-width:560px){.dashboard{padding:1.25rem 1rem 2rem}.db-welcome{flex-direction:column;align-items:flex-start;gap:.75rem}.db-welcome-text h1{font-size:1.4rem}.db-stats-row{grid-template-columns:1fr 1fr;gap:.75rem}.db-stat-card{flex-direction:column;align-items:flex-start;gap:.6rem;padding:1rem}.db-stat-value{font-size:1.2rem}.db-skeleton-grid{grid-template-columns:1fr 1fr;gap:.75rem}.db-skeleton-card{flex-direction:column;align-items:flex-start;gap:.6rem}.db-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.db-tab{white-space:nowrap;font-size:.78rem;padding:.5rem .6rem}.db-hw-grid-3{grid-template-columns:1fr 1fr 1fr}}[data-theme=dark] .db-welcome{border-bottom-color:#ffffff0f}[data-theme=dark] .db-stat-card,[data-theme=dark] .db-card,[data-theme=dark] .db-quick-action,[data-theme=dark] .db-skeleton-card,[data-theme=dark] .db-error-card,[data-theme=dark] .db-tabs{background:#1e1e1e;border-color:#2a2a2a;box-shadow:0 2px 8px #0006}[data-theme=dark] .db-tab{color:var(--text-muted)}[data-theme=dark] .db-tab:hover{color:var(--text-secondary)}[data-theme=dark] .db-tab.active{color:var(--accent)}[data-theme=dark] .db-tab-indicator{background:#16a34a1a;border-color:#16a34a33}[data-theme=dark] .db-quick-action:hover{border-color:var(--qa-color, var(--accent));box-shadow:0 4px 20px #00000080}[data-theme=dark] .db-progress-track{background:#ffffff0f}[data-theme=dark] .ring-container{--ring-bg: rgba(255, 255, 255, .08)}[data-theme=dark] .db-hw-stat{background:#ffffff08}[data-theme=dark] .db-inactive-note{border-top-color:#ffffff0f}[data-theme=dark] .db-activity-item{border-bottom-color:#ffffff0a}[data-theme=dark] .skel-circle,[data-theme=dark] .skel-line{background:linear-gradient(90deg,#ffffff08 25%,#ffffff0f,#ffffff08 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}[data-theme=dark] .db-chart-tooltip{background:#1e1e1ef5;border-color:#ffffff1a;box-shadow:0 4px 20px #00000080}[data-theme=dark] .tooltip-label,[data-theme=dark] .tooltip-name{color:#9ca3af}[data-theme=dark] .recharts-cartesian-axis-tick-value{fill:#6b7280!important}[data-theme=dark] .recharts-legend-item-text{color:#9ca3af!important}[data-theme=dark] .db-export-btn{background:#15803d;border-color:#15803d}[data-theme=dark] .db-export-btn:hover:not(:disabled){background:#16a34a;border-color:#16a34a;box-shadow:0 2px 10px #16a34a66}.db-highlight-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem}.db-mini-stat{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:.85rem .5rem;border-radius:var(--radius-sm);background:#00000005;border:1px solid rgba(0,0,0,.04);min-height:70px}.db-mini-stat-val{font-size:1.05rem;font-weight:800;letter-spacing:-.02em;line-height:1.1}.db-mini-stat-lbl{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-top:.3rem;line-height:1.2}[data-theme=dark] .db-mini-stat{background:#ffffff08;border-color:#ffffff0d}.db-amount-badge{display:inline-flex;align-items:center;padding:.3rem .7rem;border-radius:6px;font-size:.78rem;font-weight:700;background:#16a34a1a;color:#16a34a;flex-shrink:0}[data-theme=dark] .db-amount-badge{background:#16a34a2e}.db-deadline-badge{display:inline-flex;align-items:center;padding:.3rem .7rem;border-radius:6px;font-size:.72rem;font-weight:700;background:#f59e0b1f;color:#d97706;flex-shrink:0}[data-theme=dark] .db-deadline-badge{background:#f59e0b2e;color:#fbbf24}.db-score-badge{display:inline-flex;align-items:center;padding:.3rem .7rem;border-radius:6px;font-size:.75rem;font-weight:700;background:#f59e0b1f;color:#d97706;flex-shrink:0}[data-theme=dark] .db-score-badge{background:#f59e0b2e;color:#fbbf24}.db-leaderboard{display:flex;flex-direction:column}.db-leaderboard-item{display:flex;align-items:center;gap:.85rem;padding:.75rem 0;border-bottom:1px solid rgba(0,0,0,.04)}.db-leaderboard-item:last-child{border-bottom:none;padding-bottom:0}.db-leaderboard-item:first-child{padding-top:0}.db-leaderboard-rank{font-size:1rem;font-weight:800;letter-spacing:-.02em;min-width:36px;flex-shrink:0}[data-theme=dark] .db-leaderboard-item{border-bottom-color:#ffffff0a}.db-course-progress-list{display:flex;flex-direction:column;gap:1.1rem}.db-course-progress-item{display:flex;flex-direction:column;gap:.5rem}.db-cp-header{display:flex;justify-content:space-between;align-items:center}.db-cp-name{font-size:.9rem;font-weight:600;color:var(--text-primary)}.db-cp-count{font-size:.78rem;font-weight:600;color:var(--text-secondary)}.db-cp-footer{display:flex;justify-content:space-between;align-items:center;font-size:.72rem;color:var(--text-muted)}.db-cp-pct{font-weight:600}.db-cp-score{font-weight:700;color:#f59e0b}.db-kpi-strip{display:grid;grid-template-columns:repeat(5,1fr);gap:0;margin-bottom:1.25rem;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.db-kpi-strip-item{padding:1rem 1.1rem;border-right:1px solid rgba(0,0,0,.05);display:flex;flex-direction:column;gap:.25rem;position:relative;min-width:0}.db-kpi-strip-item:last-child{border-right:none}.db-kpi-strip-head{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.db-kpi-strip-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.db-kpi-strip-value{font-size:1.4rem;font-weight:800;letter-spacing:-.03em;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.db-kpi-strip-spark{height:32px;margin:0 -.4rem -.2rem;pointer-events:none}[data-theme=dark] .db-kpi-strip{background:#1e1e1e;border-color:#2a2a2a}[data-theme=dark] .db-kpi-strip-item{border-right-color:#ffffff0d}.db-attendance-hero{display:flex;align-items:center;gap:1.5rem;padding:.5rem 0}.db-attendance-hero-stat{flex-shrink:0;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:140px;padding-right:1.5rem;border-right:1px solid rgba(0,0,0,.06)}.db-attendance-hero-value{font-size:2.6rem;font-weight:800;letter-spacing:-.04em;line-height:1}.db-attendance-hero-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-top:.4rem}.db-attendance-hero-meta{font-size:.72rem;color:var(--text-secondary);margin-top:.25rem}.db-attendance-hero-chart{flex:1;min-width:0}[data-theme=dark] .db-attendance-hero-stat{border-right-color:#ffffff0f}.db-stack-bar-wrap{display:flex;flex-direction:column;gap:.85rem}.db-stack-bar{display:flex;width:100%;height:36px;border-radius:10px;overflow:hidden;background:#0000000a}.db-stack-segment{display:flex;align-items:center;justify-content:center;height:100%;position:relative;transition:filter .18s ease;min-width:0}.db-stack-segment:hover{filter:brightness(1.08)}.db-stack-label{color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.02em;text-shadow:0 1px 2px rgba(0,0,0,.2)}.db-stack-legend{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.5rem 1rem}.db-stack-legend-item{display:flex;align-items:center;gap:.5rem;font-size:.78rem}.db-stack-legend-dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.db-stack-legend-name{color:var(--text-secondary);flex:1}.db-stack-legend-val{color:var(--text-primary);font-weight:700}.db-stack-legend-pct{color:var(--text-muted);font-size:.72rem;font-variant-numeric:tabular-nums;min-width:42px;text-align:right}[data-theme=dark] .db-stack-bar{background:#ffffff0d}.db-timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;flex-wrap:wrap;gap:.5rem}.db-timeline-title{font-size:.78rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.db-timeline-key{display:flex;flex-wrap:wrap;gap:.6rem;font-size:.7rem;color:var(--text-muted)}.db-timeline-key span{display:inline-flex;align-items:center;gap:.3rem}.db-timeline-dot{width:8px;height:8px;border-radius:2px;flex-shrink:0}.db-timeline-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(20px,1fr));gap:4px;padding:.4rem 0}.db-timeline-cell{aspect-ratio:1;border-radius:4px;cursor:default;transition:transform .15s ease,box-shadow .15s ease}.db-timeline-cell:hover{transform:scale(1.15);box-shadow:0 2px 8px #0000002e}.db-att-table-shell{display:flex;flex-direction:column;gap:1rem;margin:-.5rem -.25rem 0}.db-att-toolbar{display:flex;flex-direction:column;gap:.75rem}.db-att-search{position:relative;display:flex;align-items:center;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:10px;padding:0 .85rem;height:38px;transition:border-color .18s ease,box-shadow .18s ease}.db-att-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #16a34a1f}.db-att-search>svg{color:var(--text-muted);flex-shrink:0}.db-att-search input{flex:1;border:none;background:transparent;outline:none;padding:0 .6rem;font-size:.85rem;font-family:inherit;color:var(--text-primary)}.db-att-search input::placeholder{color:var(--text-muted)}.db-att-search-clear{border:none;background:transparent;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .15s ease,color .15s ease}.db-att-search-clear:hover{background:#0000000a;color:var(--text-primary)}[data-theme=dark] .db-att-search{background:#1e1e1e;border-color:#2a2a2a}[data-theme=dark] .db-att-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #16a34a2e}[data-theme=dark] .db-att-search-clear:hover{background:#ffffff0d}.db-att-chips{display:flex;flex-wrap:wrap;gap:.45rem}.db-att-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.4rem .75rem;border-radius:20px;border:1px solid rgba(0,0,0,.08);background:#fff;color:var(--text-secondary);font-size:.78rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .18s ease}.db-att-chip:hover{border-color:#0000002e;color:var(--text-primary)}.db-att-chip.active{font-weight:700}.db-att-chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.db-att-chip-count{background:#0000000f;padding:1px 7px;border-radius:10px;font-size:.7rem;font-weight:700;margin-left:.15rem;font-variant-numeric:tabular-nums}.db-att-chip.active .db-att-chip-count{background:#0000000d}[data-theme=dark] .db-att-chip{background:#1e1e1e;border-color:#2a2a2a}[data-theme=dark] .db-att-chip:hover{border-color:#3a3a3a}[data-theme=dark] .db-att-chip-count{background:#ffffff14}.db-att-table-wrap{width:100%;overflow-x:auto;border:1px solid rgba(0,0,0,.06);border-radius:10px}.db-att-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.84rem;min-width:720px}.db-att-table thead{background:#f7f7f7}.db-att-table thead th{padding:.7rem .85rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);border-bottom:1px solid rgba(0,0,0,.06);white-space:nowrap;-webkit-user-select:none;user-select:none}.db-att-table thead th.sortable:hover{color:var(--text-primary);background:#00000005}.db-att-th-inner{display:inline-flex;align-items:center;gap:.4rem}.db-att-th-icon{color:var(--text-muted);display:inline-flex}.db-att-sort-arrow{font-size:.55rem;color:var(--accent);margin-left:2px}.db-att-row-num{width:40px;color:var(--text-muted);font-size:.75rem;font-variant-numeric:tabular-nums;text-align:center;padding:.65rem .5rem;border-bottom:1px solid rgba(0,0,0,.04);background:#00000004}.db-att-table tbody td{padding:.65rem .85rem;border-bottom:1px solid rgba(0,0,0,.04);color:var(--text-secondary);vertical-align:middle;white-space:nowrap}.db-att-table tbody tr:last-child td{border-bottom:none}.db-att-table tbody tr:hover td,.db-att-table tbody tr:hover .db-att-row-num{background:#16a34a08}.db-att-primary{color:var(--text-primary);font-weight:600;font-size:.85rem;line-height:1.3}.db-att-secondary{color:var(--text-muted);font-size:.77rem;line-height:1.3}.db-att-date{color:var(--text-primary);font-size:.83rem;font-weight:500;font-variant-numeric:tabular-nums}.db-att-pill{display:inline-block;padding:.3rem .7rem;border-radius:6px;font-size:.74rem;font-weight:700;letter-spacing:.02em}.db-att-month-pill{display:inline-block;padding:.25rem .6rem;border-radius:6px;background:#f59e0b24;color:#d97706;font-size:.74rem;font-weight:700}[data-theme=dark] .db-att-table-wrap{border-color:#2a2a2a}[data-theme=dark] .db-att-table thead{background:#232323}[data-theme=dark] .db-att-table thead th{border-bottom-color:#ffffff0f}[data-theme=dark] .db-att-table thead th.sortable:hover{background:#ffffff08}[data-theme=dark] .db-att-row-num{background:#ffffff05;border-bottom-color:#ffffff0a}[data-theme=dark] .db-att-table tbody td{border-bottom-color:#ffffff0a}[data-theme=dark] .db-att-table tbody tr:hover td,[data-theme=dark] .db-att-table tbody tr:hover .db-att-row-num{background:#16a34a0f}[data-theme=dark] .db-att-month-pill{background:#f59e0b2e;color:#fbbf24}.db-att-pagination{display:flex;justify-content:space-between;align-items:center;padding-top:.5rem;flex-wrap:wrap;gap:.75rem}.db-att-page-info{font-size:.78rem;color:var(--text-muted)}.db-att-page-controls{display:flex;align-items:center;gap:.5rem}.db-att-page-btn{padding:.4rem .85rem;border-radius:7px;border:1px solid rgba(0,0,0,.08);background:#fff;font-size:.78rem;font-weight:600;font-family:inherit;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.db-att-page-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.db-att-page-btn:disabled{opacity:.4;cursor:not-allowed}.db-att-page-current{font-size:.78rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;min-width:50px;text-align:center}[data-theme=dark] .db-att-page-btn{background:#1e1e1e;border-color:#2a2a2a}@media(max-width:720px){.db-att-table{min-width:640px}.db-att-chip{font-size:.72rem;padding:.32rem .6rem}}@media(max-width:560px){.db-att-pagination{flex-direction:column;align-items:stretch}.db-att-page-controls{justify-content:center}}.db-rate-badge{display:inline-block;padding:.25rem .65rem;border-radius:6px;font-size:.78rem;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.01em}@media(max-width:720px){.db-attendance-hero{flex-direction:column;align-items:stretch;gap:1rem}.db-attendance-hero-stat{flex-direction:row;justify-content:center;gap:1rem;padding-right:0;padding-bottom:1rem;border-right:none;border-bottom:1px solid rgba(0,0,0,.06)}[data-theme=dark] .db-attendance-hero-stat{border-bottom-color:#ffffff0f}.db-attendance-hero-value{font-size:2.1rem}}@media(max-width:560px){.db-timeline-grid{grid-template-columns:repeat(15,1fr)}.db-stack-bar{height:30px}.db-stack-label{font-size:.68rem}}.db-trend-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-wrap:wrap}.db-trend-summary{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--text-secondary)}.db-trend-summary b{font-weight:800;font-size:.92rem;letter-spacing:-.01em}.db-trend-divider{color:var(--text-muted);opacity:.5}.db-range-filter{display:inline-flex;align-items:center;gap:2px;padding:3px;border-radius:8px;background:#0000000a;border:1px solid rgba(0,0,0,.05)}.db-range-btn{padding:.35rem .7rem;border:none;background:transparent;border-radius:6px;font-size:.72rem;font-weight:700;letter-spacing:.04em;color:var(--text-muted);font-family:inherit;cursor:pointer;transition:all .18s ease;min-width:36px}.db-range-btn:hover:not(:disabled):not(.active){color:var(--text-secondary);background:#00000008}.db-range-btn.active{background:#fff;color:var(--accent);box-shadow:0 1px 3px #00000014}.db-range-btn:disabled{opacity:.5;cursor:not-allowed}[data-theme=dark] .db-range-filter{background:#ffffff0a;border-color:#ffffff0f}[data-theme=dark] .db-range-btn:hover:not(:disabled):not(.active){background:#ffffff0a}[data-theme=dark] .db-range-btn.active{background:#2a2a2a;color:var(--accent)}@media(max-width:560px){.db-trend-header{flex-direction:column;align-items:stretch}.db-range-filter{justify-content:space-between;width:100%}.db-range-btn{flex:1}}.db-pie-legend{display:flex;justify-content:center;gap:1.2rem;flex-wrap:wrap;margin-top:.5rem;padding-top:.75rem;border-top:1px solid rgba(0,0,0,.05);font-size:.78rem;color:var(--text-secondary)}.db-pie-legend b{font-weight:800;margin-right:.25rem}[data-theme=dark] .db-pie-legend{border-top-color:#ffffff0d}.db-table-wrap{width:100%;overflow-x:auto;margin:-.25rem 0}.db-table{width:100%;border-collapse:collapse;font-size:.85rem}.db-table thead th{text-align:left;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);padding:.5rem .85rem .6rem;border-bottom:1px solid rgba(0,0,0,.06);background:#00000004}.db-table tbody td{padding:.7rem .85rem;border-bottom:1px solid rgba(0,0,0,.04);color:var(--text-secondary);vertical-align:middle}.db-table tbody tr:last-child td{border-bottom:none}.db-table tbody tr:hover td{background:#00000005}.db-table-primary{color:var(--text-primary);font-weight:600;font-size:.85rem;line-height:1.3}.db-table-secondary{color:var(--text-muted);font-size:.75rem;line-height:1.3;margin-top:.1rem}.db-table-amount{display:inline-block;font-weight:700;color:#16a34a;font-size:.9rem;letter-spacing:-.01em}[data-theme=dark] .db-table thead th{background:#ffffff05;border-bottom-color:#ffffff0f}[data-theme=dark] .db-table tbody td{border-bottom-color:#ffffff0a}[data-theme=dark] .db-table tbody tr:hover td{background:#ffffff05}@media(max-width:900px){.db-kpi-strip{grid-template-columns:repeat(3,1fr)}.db-kpi-strip-item:nth-child(3){border-right:none}.db-kpi-strip-item:nth-child(n+4){border-top:1px solid rgba(0,0,0,.05)}[data-theme=dark] .db-kpi-strip-item:nth-child(n+4){border-top-color:#ffffff0d}}@media(max-width:560px){.db-kpi-strip{grid-template-columns:repeat(2,1fr)}.db-kpi-strip-item{padding:.85rem;border-right:1px solid rgba(0,0,0,.05);border-top:1px solid rgba(0,0,0,.05)}.db-kpi-strip-item:nth-child(odd){border-right:1px solid rgba(0,0,0,.05)}.db-kpi-strip-item:nth-child(2n){border-right:none}.db-kpi-strip-item:nth-child(-n+2){border-top:none}.db-kpi-strip-value{font-size:1.15rem}.db-table{font-size:.78rem}.db-table thead th{padding:.4rem .55rem .5rem}.db-table tbody td{padding:.55rem}}.db-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1rem}.db-kpi-card{display:flex;flex-direction:column;gap:.4rem;padding:1.2rem 1.15rem;border-radius:var(--radius-lg);background:linear-gradient(135deg,#fff,#fafafa);border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.db-kpi-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.3rem}.db-kpi-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center}.db-kpi-trend{display:inline-flex;align-items:center;gap:2px;padding:.2rem .5rem;border-radius:14px;font-size:.7rem;font-weight:700}.db-kpi-trend.up{background:#16a34a1f;color:#16a34a}.db-kpi-trend.down{background:#ef44441f;color:#ef4444}.db-kpi-value{font-size:1.55rem;font-weight:800;letter-spacing:-.03em;line-height:1.1}.db-kpi-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.db-kpi-sub{font-size:.72rem;color:var(--text-secondary);margin-top:.15rem}[data-theme=dark] .db-kpi-card{background:linear-gradient(135deg,#1e1e1e,#1a1a1a);border-color:#2a2a2a;box-shadow:0 2px 8px #0006}.db-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1rem}.db-grid-3 .db-card{margin-bottom:0}.db-gauge-caption{font-size:.75rem;color:var(--text-secondary);text-align:center;margin-top:-.25rem}.db-activity-item-rich{gap:.75rem}.db-activity-icon{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}@media(max-width:900px){.db-kpi-grid{grid-template-columns:1fr 1fr}.db-grid-3{grid-template-columns:1fr}}@media(max-width:720px){.db-highlight-grid,.db-stats-row-3{grid-template-columns:1fr 1fr}.db-hw-grid-5{grid-template-columns:repeat(3,1fr)}}@media(max-width:560px){.db-highlight-grid{grid-template-columns:1fr 1fr;gap:.5rem}.db-mini-stat{padding:.7rem .4rem;min-height:60px}.db-mini-stat-val{font-size:.95rem}.db-mini-stat-lbl{font-size:.6rem}.db-stats-row-3,.db-hw-grid-5{grid-template-columns:1fr 1fr}.db-leaderboard-rank{min-width:28px;font-size:.9rem}.db-amount-badge,.db-deadline-badge,.db-score-badge{font-size:.68rem;padding:.25rem .55rem}.db-kpi-grid{grid-template-columns:1fr 1fr;gap:.6rem}.db-kpi-card{padding:.9rem .85rem}.db-kpi-value{font-size:1.2rem}.db-kpi-icon{width:32px;height:32px}.db-activity-icon{width:28px;height:28px}}.admin-container{max-width:960px;margin:0 auto;padding:2.5rem 1.5rem}.admin-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.admin-header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .25rem;color:var(--text-primary)}.admin-subtitle{color:var(--text-secondary);font-size:.9rem;margin:0}.user-tabs{display:flex;gap:.25rem;padding:.3rem;border-radius:var(--radius-md);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.user-tab{position:relative;flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem .75rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:500;font-family:inherit;cursor:pointer;transition:color .2s ease;z-index:1}.user-tab:hover{color:var(--text-primary)}.user-tab.active{color:var(--accent);font-weight:600}.user-tab-indicator{position:absolute;inset:0;border-radius:var(--radius-sm);background:#16a34a0f;border:1px solid rgba(22,163,74,.15);z-index:-1}.user-toolbar{display:flex;align-items:center;gap:.75rem;margin-bottom:1.25rem;padding:.6rem .75rem;border-radius:var(--radius-lg);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm)}.toolbar-search{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0;padding:.35rem .65rem;border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.08);background:var(--bg-secondary);transition:border-color .2s ease,box-shadow .2s ease;color:var(--text-muted)}.toolbar-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #16a34a14}.toolbar-search:focus-within svg{color:var(--accent)}.toolbar-search input{width:100%;border:none;background:transparent;font-size:.85rem;font-family:inherit;color:var(--text-primary);outline:none;padding:0}.toolbar-search input::placeholder{color:var(--text-muted)}.toolbar-search-clear{display:flex;align-items:center;justify-content:center;width:20px;height:20px;padding:0;border:none;border-radius:50%;background:#0000000f;color:var(--text-muted);cursor:pointer;flex-shrink:0;transition:all .15s ease}.toolbar-search-clear:hover{background:#0000001f;color:var(--text-primary)}.toolbar-filters{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.toolbar-select{padding:.4rem .6rem;border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);font-size:.8rem;font-family:inherit;outline:none;cursor:pointer;transition:border-color .2s ease}.toolbar-select:focus{border-color:var(--accent)}.date-cell{color:var(--text-muted)!important;font-size:.8rem!important}.table-card{border-radius:var(--radius-lg);overflow:hidden;background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm)}.table-wrapper{overflow-x:auto;max-height:400px;overflow-y:auto}.admin-table{width:100%;border-collapse:collapse}.admin-table th{padding:.85rem 1.25rem;text-align:left;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid rgba(0,0,0,.06);background:var(--bg-secondary);position:sticky;top:0;z-index:1}.sortable-th{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s ease}.sortable-th:hover{color:var(--text-primary)}.sort-icon{display:inline-flex;align-items:center;vertical-align:middle;margin-left:.3rem;opacity:.25;transition:opacity .2s ease}.sortable-th:hover .sort-icon{opacity:.5}.sort-icon.sort-active{opacity:1;color:var(--accent)}.admin-table td{padding:.85rem 1.25rem;font-size:.9rem;color:var(--text-secondary);border-bottom:1px solid rgba(0,0,0,.04);transition:background .2s ease}.admin-table tr:hover td{background:#16a34a05}.admin-table tr:last-child td{border-bottom:none}.user-cell{display:flex;align-items:center;gap:.75rem}.table-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;color:#fff;flex-shrink:0}.role-bg-student{background:linear-gradient(135deg,#22c55e,#16a34a)}.role-bg-instructor{background:linear-gradient(135deg,#f59e0b,#d97706)}.role-bg-admin{background:linear-gradient(135deg,#ef4444,#dc2626)}.user-cell-info{display:flex;flex-direction:column;line-height:1.3}.user-cell-name{font-weight:600;color:var(--text-primary);font-size:.875rem}.user-cell-username{font-size:.75rem;color:var(--text-muted)}.email-cell{color:var(--text-secondary)!important}.id-cell{color:var(--text-muted)!important;font-family:SF Mono,Fira Code,monospace;font-size:.8rem!important}.role-chip{display:inline-flex;padding:.2rem .65rem;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.role-student{background:#16a34a14;color:#16a34a;border:1px solid rgba(22,163,74,.2)}.role-instructor{background:#f59e0b14;color:#d97706;border:1px solid rgba(245,158,11,.2)}.role-admin{background:#ef444414;color:#dc2626;border:1px solid rgba(239,68,68,.2)}.pagination{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-top:1.25rem;padding:.65rem 1rem;border-radius:var(--radius-lg);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm)}.pagination-info{font-size:.8rem;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.pagination-controls{display:flex;align-items:center;gap:.35rem}.page-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:all .2s ease}.page-btn:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:#16a34a0a}.page-btn:disabled{opacity:.25;cursor:not-allowed}.page-numbers{display:flex;align-items:center;gap:.2rem}.page-num{display:flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 .35rem;border:1px solid transparent;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);cursor:pointer;font-size:.8rem;font-weight:500;font-family:inherit;transition:all .2s ease}.page-num:hover{background:#16a34a0a;color:var(--accent)}.page-num.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:700;box-shadow:0 2px 8px #16a34a40}.page-ellipsis{display:flex;align-items:center;justify-content:center;width:24px;height:32px;color:var(--text-muted);font-size:.85rem;-webkit-user-select:none;user-select:none}.table-skeleton{border-radius:var(--radius-lg);padding:1.25rem;background:#fff}.skeleton-row{height:48px;background:linear-gradient(90deg,#f3f4f6 25%,#e5e7eb,#f3f4f6 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-sm);margin-bottom:.5rem}.skeleton-row:last-child{margin-bottom:0}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.create-form-card{border-radius:var(--radius-lg);padding:1.5rem 1.75rem;width:100%;max-width:440px;background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm)}.create-form-card-wide{max-width:880px}.create-form-card-wide .sms-options{max-height:280px}.create-form-header{text-align:center;margin-bottom:1.25rem}.create-form-header h2{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:0 0 .2rem;letter-spacing:-.01em}.create-form-header p{font-size:.78rem;color:var(--text-muted);margin:0}.create-form-card .input-row{display:flex;gap:.6rem;width:100%}.create-form-card .input-row .input-group{flex:1 1 0;min-width:0;max-width:100%}.create-form-card .input-group{margin-bottom:.85rem}.create-form-card .input-group label{display:block;margin-bottom:.3rem;font-size:.7rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.create-form-card .input-wrapper{display:flex;align-items:center;gap:.5rem;padding:0 .65rem;border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-sm);background:#fff;transition:all .3s ease}.create-form-card .input-wrapper svg{color:var(--text-muted);flex-shrink:0;transition:color .3s ease;width:15px;height:15px}.create-form-card .input-wrapper:focus-within{border-color:var(--accent);background:#16a34a05;box-shadow:0 0 0 3px #16a34a14,0 2px 8px #16a34a0f}.create-form-card .input-wrapper:focus-within svg{color:var(--accent)}.create-form-card .input-wrapper input,.create-form-card .input-wrapper select{width:100%;padding:.5rem 0;border:none;background:transparent;color:var(--text-primary);font-size:.85rem;font-family:inherit;outline:none}.create-form-card .input-wrapper input::placeholder{color:var(--text-muted)}.create-form-card .input-wrapper select{cursor:pointer}.create-form-card .input-wrapper select option{background:#fff;color:var(--text-primary)}.create-form-card .btn-submit{width:100%;padding:.6rem;margin-top:.25rem;border:none;border-radius:var(--radius-sm);background:linear-gradient(135deg,#16a34a,#059669);color:#fff;font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;position:relative;overflow:hidden;transition:box-shadow .3s ease}.create-form-card .btn-submit:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.15) 50%,transparent 60%);transform:translate(-100%);transition:transform .6s ease}.create-form-card .btn-submit:hover:not(:disabled):before{transform:translate(100%)}.create-form-card .btn-submit:hover:not(:disabled){box-shadow:0 4px 20px #16a34a4d,0 2px 8px #16a34a26}.create-form-card .btn-submit:disabled{opacity:.6;cursor:not-allowed}.admin-loading{margin-top:1rem}.admin-table tr{cursor:pointer}.detail-breadcrumb{margin-bottom:1.5rem}.back-link{display:inline-flex;align-items:center;gap:.35rem;color:var(--text-secondary);font-size:.875rem;font-weight:500;text-decoration:none;transition:color .2s ease}.back-link:hover{color:var(--accent)}.detail-header{display:flex;align-items:center;gap:1.25rem;margin-bottom:2rem}.detail-avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:#fff;flex-shrink:0;box-shadow:0 4px 16px #0000001f}.detail-header-info h1{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);margin:0 0 .25rem}.detail-header-meta{display:flex;align-items:center;gap:.75rem}.detail-username{color:var(--text-secondary);font-size:.9rem}.detail-card h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 1.25rem}.detail-field{display:flex;flex-direction:column;gap:.25rem}.detail-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.detail-value{font-size:.95rem;color:var(--text-primary);font-weight:500}.detail-skeleton{border-radius:var(--radius-lg);padding:1.75rem;background:#fff}.detail-empty{text-align:center;padding:4rem 0;color:var(--text-secondary)}.detail-empty h2{margin:0 0 1rem;color:var(--text-primary)}@media(max-width:640px){.detail-grid{grid-template-columns:1fr}.detail-header{flex-direction:column;text-align:center}.detail-header-meta{justify-content:center}}.status-chip{display:inline-flex;padding:.2rem .65rem;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.status-active{background:#16a34a14;color:#16a34a;border:1px solid rgba(22,163,74,.2)}.status-inactive{background:#ef444414;color:#dc2626;border:1px solid rgba(239,68,68,.2)}.detail-actions-card{margin-top:1.25rem}.action-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 0;border-bottom:1px solid rgba(0,0,0,.06)}.action-row:last-child{border-bottom:none;padding-bottom:0}.action-row:first-child{padding-top:0}.action-info{display:flex;flex-direction:column;gap:.15rem;min-width:0}.action-title{font-size:.875rem;font-weight:600;color:var(--text-primary)}.action-title-danger{color:var(--danger)}.action-desc{font-size:.8rem;color:var(--text-muted)}.action-select{padding:.4rem .75rem;border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-sm);background:#fff;color:var(--text-primary);font-size:.85rem;font-family:inherit;outline:none;cursor:pointer}.action-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px #16a34a14}.action-input{padding:.4rem .75rem;border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-sm);background:#fff;color:var(--text-primary);font-size:.85rem;font-family:inherit;outline:none;width:180px}.action-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #16a34a14}.action-confirm-text{font-size:.85rem;font-weight:500;color:var(--danger);white-space:nowrap}.action-btn{padding:.4rem .85rem;border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;border:1px solid transparent;transition:all .2s ease}.action-btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.action-btn-primary:hover:not(:disabled){box-shadow:0 2px 8px #16a34a4d}.action-btn-outline{background:transparent;color:var(--accent);border-color:#16a34a4d}.action-btn-outline:hover:not(:disabled){background:#16a34a0f}.action-btn-ghost{background:transparent;color:var(--text-secondary);border-color:#0000001a}.action-btn-ghost:hover:not(:disabled){background:#00000008}.action-btn-warning{background:#f59e0b;color:#fff;border-color:#f59e0b}.action-btn-warning:hover:not(:disabled){box-shadow:0 2px 8px #f59e0b4d}.action-btn-danger{background:#ef444414;color:var(--danger);border-color:#ef444433}.action-btn-danger:hover:not(:disabled){background:var(--danger);color:#fff;border-color:var(--danger)}.action-row-danger{margin-top:.5rem;padding-top:1rem;border-top:1px solid rgba(239,68,68,.1);border-bottom:none}[data-theme=dark] .status-active{background:#16a34a26;border-color:#16a34a4d}[data-theme=dark] .status-inactive{background:#ef444426;border-color:#ef44444d}[data-theme=dark] .action-select{background:#ffffff0a;border-color:#ffffff1a;color:var(--text-primary)}[data-theme=dark] .action-select option{background:#1e1e1e}[data-theme=dark] .action-input{background:#ffffff0a;border-color:#ffffff1a;color:var(--text-primary)}[data-theme=dark] .action-btn-ghost{border-color:#ffffff1a}[data-theme=dark] .action-btn-ghost:hover:not(:disabled){background:#ffffff0d}[data-theme=dark] .table-card,[data-theme=dark] .user-toolbar{background:#161616;border-color:#ffffff0f}[data-theme=dark] .toolbar-search{background:#ffffff0a;border-color:#ffffff14}[data-theme=dark] .toolbar-search input{color:var(--text-primary)}[data-theme=dark] .toolbar-search-clear{background:#ffffff14;color:var(--text-muted)}[data-theme=dark] .toolbar-search-clear:hover{background:#ffffff26}[data-theme=dark] .toolbar-select{background:#ffffff0a;border-color:#ffffff14;color:var(--text-primary)}[data-theme=dark] .toolbar-select option{background:#1e1e1e}[data-theme=dark] .user-tabs{background:#161616;border-color:#ffffff0f}[data-theme=dark] .user-tab-indicator{background:#16a34a1a;border-color:#16a34a33}[data-theme=dark] .pagination{background:#161616;border-color:#ffffff0f}[data-theme=dark] .admin-table th{border-bottom-color:#ffffff0f;background:#111}[data-theme=dark] .admin-table tr:hover td{background:#16a34a0a}[data-theme=dark] .skeleton-row{background:linear-gradient(90deg,#1e1e1e 25%,#2a2a2a,#1e1e1e 75%);background-size:200% 100%}[data-theme=dark] .table-skeleton{background:#161616}[data-theme=dark] .create-form-card{background:#161616;border-color:#ffffff0f}[data-theme=dark] .create-form-card .input-wrapper{border-color:#ffffff1a;background:#ffffff0a}[data-theme=dark] .create-form-card .input-wrapper:focus-within{background:#16a34a0f}[data-theme=dark] .create-form-card .input-wrapper select option{background:#1e1e1e;color:var(--text-primary)}[data-theme=dark] .page-btn{border-color:#ffffff14}[data-theme=dark] .page-btn:hover:not(:disabled){background:#16a34a14}[data-theme=dark] .page-num:hover{background:#16a34a14}[data-theme=dark] .page-num.active{background:var(--accent);border-color:var(--accent)}[data-theme=dark] .detail-skeleton{background:#161616}[data-theme=dark] .role-student{background:#16a34a26;border-color:#16a34a4d}[data-theme=dark] .role-instructor{background:#f59e0b26;border-color:#f59e0b4d}[data-theme=dark] .role-admin{background:#ef444426;border-color:#ef44444d}.detail-page-container{max-width:720px;margin:0 auto}.detail-breadcrumb{margin-bottom:1.25rem}.detail-hero{display:flex;align-items:center;gap:1.25rem;padding:1.75rem;border-radius:var(--radius-lg);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.detail-hero-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#059669);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;box-shadow:0 4px 16px #16a34a40}.detail-hero-avatar img{width:100%;height:100%;object-fit:cover}.detail-hero-info h1{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);margin:0 0 .15rem}.detail-hero-email{font-size:.875rem;color:var(--text-secondary);margin:0 0 .5rem}.detail-hero-badges{display:flex;gap:.5rem;align-items:center}.detail-tabs{display:flex;gap:.25rem;padding:.3rem;border-radius:var(--radius-md);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.detail-tab{position:relative;flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem .75rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:500;font-family:inherit;cursor:pointer;transition:color .2s ease;z-index:1}.detail-tab:hover{color:var(--text-primary)}.detail-tab.active{color:var(--accent);font-weight:600}.detail-tab-indicator{position:absolute;inset:0;border-radius:var(--radius-sm);background:#16a34a0f;border:1px solid rgba(22,163,74,.15);z-index:-1}.detail-tab-content{min-height:300px}.detail-card{border-radius:var(--radius-lg);padding:1.75rem;background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm)}.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem}.detail-field{display:flex;flex-direction:column;gap:.3rem}.detail-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.detail-value{font-size:.9rem;font-weight:500;color:var(--text-primary)}.detail-actions{display:flex;flex-direction:column;gap:0}.action-row{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;border-bottom:1px solid rgba(0,0,0,.06);gap:1rem}.action-row:last-child{border-bottom:none}.action-row-danger{margin-top:.5rem;padding-top:1.25rem;border-top:1px solid rgba(239,68,68,.2)}.action-info{display:flex;flex-direction:column;gap:.15rem;flex:1;min-width:0}.action-title{font-size:.9rem;font-weight:600;color:var(--text-primary)}.action-title-danger{color:#dc2626}.action-desc{font-size:.8rem;color:var(--text-secondary)}.action-inline{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.action-select{padding:.45rem .75rem;border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.12);background:#fff;font-size:.85rem;font-family:inherit;color:var(--text-primary);outline:none}.action-select:focus{border-color:var(--accent)}.action-input{padding:.45rem .75rem;border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.12);background:#fff;font-size:.85rem;font-family:inherit;color:var(--text-primary);outline:none;width:160px}.action-input:focus{border-color:var(--accent)}.action-btn{padding:.45rem 1rem;border-radius:var(--radius-sm);border:none;font-size:.8rem;font-weight:600;font-family:inherit;cursor:pointer;white-space:nowrap;transition:all .15s ease}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn-primary{background:var(--accent);color:#fff}.action-btn-primary:hover:not(:disabled){background:#15803d}.action-btn-outline{background:transparent;border:1px solid rgba(0,0,0,.12);color:var(--text-primary)}.action-btn-outline:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}.action-btn-ghost{background:transparent;color:var(--text-secondary)}.action-btn-ghost:hover:not(:disabled){color:var(--text-primary)}.action-btn-warning{background:#f59e0b1f;color:#d97706;border:1px solid rgba(245,158,11,.2)}.action-btn-warning:hover:not(:disabled){background:#f59e0b33}.action-btn-danger{background:#ef44441f;color:#dc2626;border:1px solid rgba(239,68,68,.2)}.action-btn-danger:hover:not(:disabled){background:#ef444433}.action-confirm-text{font-size:.8rem;font-weight:500;color:#dc2626;white-space:nowrap}.detail-skeleton{padding:2rem;border-radius:var(--radius-lg)}.skeleton-row{height:16px;background:linear-gradient(90deg,#0000000a 25%,#00000014,#0000000a 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:8px;margin-bottom:1rem}.skeleton-row:last-child{margin-bottom:0;width:60%}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.detail-empty{text-align:center;padding:4rem 2rem}.detail-empty h2{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}[data-theme=dark] .detail-hero,[data-theme=dark] .detail-tabs{background:#161616;border-color:#ffffff0f}[data-theme=dark] .detail-tab-indicator{background:#16a34a1a;border-color:#16a34a33}[data-theme=dark] .detail-card{background:#161616;border-color:#ffffff0f}[data-theme=dark] .action-row{border-bottom-color:#ffffff0f}[data-theme=dark] .action-row-danger{border-top-color:#ef444426}[data-theme=dark] .action-select,[data-theme=dark] .action-input{background:#ffffff0a;border-color:#ffffff1a;color:var(--text-primary)}[data-theme=dark] .skeleton-row{background:linear-gradient(90deg,#ffffff08 25%,#ffffff0f,#ffffff08 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@media(max-width:768px){.admin-container{padding:1.5rem 1rem}.admin-header h1{font-size:1.35rem}.admin-table .col-email,.admin-table .col-id{display:none}.create-form-card{max-width:100%;padding:1.25rem}.create-form-card .input-row{flex-direction:column;gap:0}}@media(max-width:600px){.admin-container{padding:1.25rem .75rem}.admin-header h1{font-size:1.15rem}.admin-subtitle{font-size:.8rem}.user-tabs{margin-bottom:1rem}.user-tab{font-size:.8rem;padding:.5rem;gap:.3rem}.user-tab svg{width:14px;height:14px}.user-toolbar{flex-direction:column;align-items:stretch;padding:.5rem;gap:.5rem;margin-bottom:1rem}.toolbar-search{padding:.3rem .5rem}.toolbar-search input{font-size:.8rem}.toolbar-filters{flex-wrap:wrap;gap:.4rem}.toolbar-select{flex:1;min-width:0;font-size:.75rem;padding:.35rem .4rem}.table-card{border-radius:var(--radius-md)}.admin-table th{padding:.6rem .75rem;font-size:.65rem}.admin-table td{padding:.6rem .75rem;font-size:.8rem}.table-avatar{width:28px;height:28px}.user-cell{gap:.5rem}.user-cell-name{font-size:.8rem}.user-cell-username{font-size:.65rem}.role-chip,.status-chip{font-size:.6rem;padding:.15rem .45rem}.pagination{flex-direction:column;gap:.5rem;padding:.5rem .75rem;margin-top:1rem}.pagination-controls{justify-content:center;gap:.25rem}.page-btn{width:28px;height:28px}.page-btn svg{width:12px;height:12px}.page-num{min-width:28px;height:28px;font-size:.75rem}.page-ellipsis{width:20px;height:28px}.pagination-info{font-size:.75rem}.create-user-section{padding:0}.create-form-card{padding:1rem;border-radius:var(--radius-md)}.create-form-header{margin-bottom:1rem}.create-form-header h2{font-size:.95rem}.create-form-header p{font-size:.72rem}.create-form-card .input-row{flex-direction:column;gap:0}.create-form-card .input-group{margin-bottom:.65rem}.create-form-card .input-group label{font-size:.65rem;margin-bottom:.2rem}.create-form-card .input-wrapper{padding:0 .5rem}.create-form-card .input-wrapper input,.create-form-card .input-wrapper select{font-size:.8rem;padding:.4rem 0}.create-form-card .btn-submit{font-size:.8rem;padding:.5rem}.detail-grid{grid-template-columns:1fr}.action-row{flex-direction:column;align-items:flex-start}.action-inline{width:100%;flex-wrap:wrap}}.table-actions{display:flex;align-items:center;gap:.35rem}.action-btn-ghost{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;border-radius:8px;background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s ease}.action-btn-ghost:hover{background:#16a34a14;color:var(--accent)}.action-btn-ghost-danger:hover{background:#ef444414;color:#dc2626}.action-btn-primary{display:inline-flex;align-items:center;gap:.3rem;padding:.4rem .85rem;border:none;border-radius:8px;background:var(--accent);color:#fff;font-size:.78rem;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .15s ease}.action-btn-primary:hover{opacity:.9}.action-btn-primary:disabled{opacity:.5;cursor:not-allowed}.action-btn-danger{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .7rem;border:none;border-radius:8px;background:#ef44441a;color:#dc2626;font-size:.75rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s ease}.action-btn-danger:hover{background:#ef44442e}.action-btn-danger:disabled{opacity:.5;cursor:not-allowed}.action-btn-outline{display:inline-flex;align-items:center;gap:.3rem;padding:.35rem .7rem;border:1px solid rgba(0,0,0,.12);border-radius:8px;background:transparent;color:var(--text-secondary);font-size:.75rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s ease}.action-btn-outline:hover{background:var(--bg-secondary);border-color:#0003}.editing-row td{padding:1rem!important}.inline-edit-fields{display:flex;gap:.75rem;align-items:flex-start}.inline-edit-fields .input-group{display:flex;flex-direction:column;gap:.25rem}.inline-edit-fields .input-group label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.inline-edit-fields .input-group input,.inline-edit-fields .input-group textarea{padding:.45rem .65rem;border:1px solid rgba(0,0,0,.12);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);font-size:.82rem;font-family:inherit;outline:none;transition:border-color .15s ease,box-shadow .15s ease;box-sizing:border-box}.inline-edit-fields .input-group input:focus,.inline-edit-fields .input-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #16a34a14}.inline-edit-actions{display:flex;gap:.5rem;margin-top:.25rem}.logo-upload-area-admin{margin-top:.35rem}.logo-upload-label-admin{display:flex;align-items:center;gap:.5rem;padding:.7rem 1rem;border:2px dashed rgba(0,0,0,.12);border-radius:10px;color:var(--text-muted);font-size:.82rem;cursor:pointer;transition:border-color .2s ease,color .2s ease,background .2s ease}.logo-upload-label-admin:hover{border-color:var(--accent);color:var(--accent);background:#16a34a08}.input-wrapper-textarea{align-items:flex-start!important}.input-wrapper-textarea textarea{flex:1;min-height:80px;resize:vertical;border:none;outline:none;background:transparent;color:var(--text-primary);font-size:.88rem;font-family:inherit;padding:.3rem 0}[data-theme=dark] .action-btn-ghost:hover{background:#22c55e1f}[data-theme=dark] .action-btn-ghost-danger:hover{background:#ef44441f}[data-theme=dark] .action-btn-outline{border-color:#ffffff1a}[data-theme=dark] .action-btn-outline:hover{border-color:#fff3;background:#ffffff0d}[data-theme=dark] .inline-edit-fields .input-group input,[data-theme=dark] .inline-edit-fields .input-group textarea{border-color:#ffffff1a;background:#ffffff0d}[data-theme=dark] .logo-upload-label-admin{border-color:#ffffff1a}[data-theme=dark] .logo-upload-label-admin:hover{border-color:var(--accent);background:#16a34a0f}@media(max-width:768px){.inline-edit-fields{flex-direction:column}.table-actions{flex-wrap:wrap}}.multi-select-container{max-height:180px;overflow-y:auto;border:1px solid rgba(0,0,0,.1);border-radius:8px;padding:.35rem;background:var(--bg-secondary)}.multi-select-option{display:flex;align-items:center;gap:.5rem;padding:.4rem .5rem;border-radius:6px;cursor:pointer;font-size:.82rem;color:var(--text-primary);transition:background .12s ease;-webkit-user-select:none;user-select:none}.multi-select-option:hover{background:#16a34a0f}.multi-select-option input[type=checkbox]{accent-color:var(--accent);width:15px;height:15px;cursor:pointer;flex-shrink:0}.multi-select-option span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.multi-select-empty{padding:1rem;text-align:center;font-size:.8rem;color:var(--text-muted)}[data-theme=dark] .multi-select-container{border-color:#ffffff1a;background:#ffffff0a}[data-theme=dark] .multi-select-option:hover{background:#16a34a1a}.group-chips{display:flex;flex-wrap:wrap;gap:.35rem}.group-chip{display:inline-flex;align-items:center;padding:.2rem .65rem;border-radius:20px;font-size:.72rem;font-weight:600;background:#3b82f614;color:#3b82f6;border:1px solid rgba(59,130,246,.2);letter-spacing:.02em}[data-theme=dark] .group-chip{background:#3b82f626;border-color:#3b82f64d}.sms-wrapper{border:1px solid rgba(0,0,0,.1);border-radius:10px;background:var(--bg-secondary);overflow:hidden;width:100%;max-width:100%;box-sizing:border-box;min-width:0}.sms-chips{display:flex;flex-wrap:wrap;gap:.3rem;padding:.5rem .5rem .25rem;border-bottom:1px solid rgba(0,0,0,.06);max-height:100px;overflow-y:auto}.sms-chip{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .2rem .2rem .35rem;border-radius:20px;font-size:.72rem;font-weight:500;background:#16a34a14;color:var(--text-primary);border:1px solid rgba(22,163,74,.18);white-space:nowrap;max-width:200px}.sms-chip-avatar{width:18px;height:18px;border-radius:50%;object-fit:cover;flex-shrink:0}.sms-chip-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sms-chip-remove{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;border:none;background:#00000014;color:var(--text-secondary);cursor:pointer;padding:0;flex-shrink:0;transition:all .15s ease}.sms-chip-remove:hover{background:#ef444426;color:#ef4444}.sms-search{display:flex;align-items:center;gap:.4rem;padding:.45rem .6rem;border-bottom:1px solid rgba(0,0,0,.06)}.sms-search-icon{color:var(--text-muted);flex-shrink:0}.sms-search-input{flex:1;border:none;background:transparent;outline:none;font-size:.82rem;color:var(--text-primary);font-family:inherit;min-width:0}.sms-search-input::placeholder{color:var(--text-muted)}.sms-search-clear{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;border:none;background:#0000000f;color:var(--text-muted);cursor:pointer;padding:0;flex-shrink:0;transition:all .15s ease}.sms-search-clear:hover{background:#0000001f;color:var(--text-primary)}.sms-count{font-size:.7rem;font-weight:600;color:var(--accent);white-space:nowrap;flex-shrink:0;padding:.15rem .5rem;border-radius:10px;background:#16a34a14}.sms-options{max-height:200px;overflow-y:auto;padding:.25rem}.sms-option{display:flex;align-items:center;gap:.45rem;padding:.4rem .5rem;border-radius:6px;cursor:pointer;font-size:.82rem;color:var(--text-primary);transition:background .12s ease;-webkit-user-select:none;user-select:none;min-width:0}.sms-option:hover{background:#16a34a0f}.sms-option-selected{background:#16a34a0d}.sms-option-selected:hover{background:#16a34a1a}.sms-option input[type=checkbox]{accent-color:var(--accent);width:15px;height:15px;cursor:pointer;flex-shrink:0}.sms-option-avatar{width:24px;height:24px;border-radius:50%;object-fit:cover;flex-shrink:0;border:1px solid rgba(0,0,0,.06)}.sms-option-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1 1 0;min-width:0;display:block}.sms-option-check{flex-shrink:0;margin-left:auto}.sms-empty{display:block;padding:1.25rem;text-align:center;font-size:.8rem;color:var(--text-muted)}[data-theme=dark] .sms-wrapper{border-color:#ffffff1a;background:#ffffff0a}[data-theme=dark] .sms-chips{border-bottom-color:#ffffff0f}[data-theme=dark] .sms-chip{background:#16a34a26;border-color:#16a34a40}[data-theme=dark] .sms-chip-remove{background:#ffffff1a}[data-theme=dark] .sms-chip-remove:hover{background:#ef444433}[data-theme=dark] .sms-search{border-bottom-color:#ffffff0f}[data-theme=dark] .sms-search-clear{background:#ffffff14}[data-theme=dark] .sms-search-clear:hover{background:#ffffff26}[data-theme=dark] .sms-count{background:#16a34a26}[data-theme=dark] .sms-option:hover{background:#16a34a1a}[data-theme=dark] .sms-option-selected{background:#16a34a14}[data-theme=dark] .sms-option-selected:hover{background:#16a34a26}[data-theme=dark] .sms-option-avatar{border-color:#ffffff14}.sms-options::-webkit-scrollbar,.sms-chips::-webkit-scrollbar{width:5px}.sms-options::-webkit-scrollbar-track,.sms-chips::-webkit-scrollbar-track{background:transparent}.sms-options::-webkit-scrollbar-thumb,.sms-chips::-webkit-scrollbar-thumb{background:#0000001f;border-radius:10px}[data-theme=dark] .sms-options::-webkit-scrollbar-thumb,[data-theme=dark] .sms-chips::-webkit-scrollbar-thumb{background:#ffffff1f}.fin-page{max-width:1180px}.fin-header{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem;margin-bottom:1.4rem}.fin-title{margin:0;font-size:1.75rem;font-weight:800;letter-spacing:-.02em;color:var(--text-primary, #1f2937)}.fin-subtitle{margin:.2rem 0 0;font-size:.88rem;color:var(--text-muted, #9ca3af)}.fin-hero-amount{display:flex;flex-direction:column;align-items:flex-end;text-align:right;padding:.75rem 1.2rem;background:linear-gradient(135deg,#16a34a14,#0891b20f);border:1px solid rgba(22,163,74,.18);border-radius:12px}.fin-hero-value{font-size:1.7rem;font-weight:800;letter-spacing:-.02em;color:#16a34a;line-height:1.1;font-variant-numeric:tabular-nums}.fin-hero-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted, #9ca3af);margin-top:.25rem}.fin-kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:.85rem;margin-bottom:1.5rem}.fin-kpi{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:12px;padding:.95rem 1.1rem;display:flex;flex-direction:column;gap:.5rem;box-shadow:0 1px 3px #00000008;transition:border-color .18s ease,box-shadow .18s ease}.fin-kpi:hover{border-color:#16a34a40;box-shadow:0 4px 14px #0000000f}.fin-kpi-head{display:flex;align-items:center;gap:.5rem}.fin-kpi-icon{width:30px;height:30px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.fin-kpi-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted, #9ca3af)}.fin-kpi-value{font-size:1.4rem;font-weight:800;letter-spacing:-.02em;color:var(--text-primary, #1f2937);line-height:1.1;font-variant-numeric:tabular-nums}[data-theme=dark] .fin-kpi{background:#1e1e1e;border-color:#ffffff0f}[data-theme=dark] .fin-hero-amount{background:linear-gradient(135deg,#16a34a26,#0891b21a);border-color:#16a34a4d}@media(max-width:800px){.fin-kpi-strip{grid-template-columns:1fr 1fr}.fin-hero-amount{width:100%;align-items:flex-start;text-align:left}}@media(max-width:480px){.fin-kpi-strip{grid-template-columns:1fr}}.admin-container{max-width:1200px;padding:1.75rem 1.5rem 3rem}.admin-header{margin-bottom:1.4rem;padding-bottom:1rem;border-bottom:1px solid rgba(0,0,0,.05)}.admin-header h1{font-size:1.7rem;font-weight:800;letter-spacing:-.025em;margin:0 0 .3rem}.admin-subtitle{color:var(--text-muted, #9ca3af);font-size:.88rem}[data-theme=dark] .admin-header{border-bottom-color:#ffffff0d}.user-tabs{display:inline-flex;gap:2px;padding:4px;border-radius:12px;background:#0000000a;border:none;box-shadow:none;margin-bottom:1.25rem}.user-tab{position:relative;flex:none;padding:.55rem 1.2rem;border-radius:9px;font-size:.86rem;font-weight:600;color:var(--text-secondary, #6b7280)}.user-tab:hover:not(.active){color:var(--text-primary, #1f2937)}.user-tab.active{color:var(--text-primary, #1f2937);font-weight:700}.user-tab-indicator{position:absolute;inset:0;border-radius:9px;background:#fff;border:none;z-index:-1;box-shadow:0 1px 3px #00000012}[data-theme=dark] .user-tabs{background:#ffffff0a}[data-theme=dark] .user-tab-indicator{background:#2a2a2a}.user-toolbar{background:transparent;border:none;box-shadow:none;padding:0;margin-bottom:1rem;gap:.6rem}.toolbar-search{background:#fff;border-radius:10px;padding:0 .95rem;height:40px;border:1px solid rgba(0,0,0,.08);box-shadow:0 1px 2px #00000005}.toolbar-search:focus-within{border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1f}.toolbar-search input{font-size:.88rem;padding:0}.toolbar-search-clear{width:18px;height:18px;background:#0000002e;color:#fff}.toolbar-select{height:40px;padding:0 2rem 0 .9rem;border-radius:10px;font-size:.85rem;font-weight:500;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right .85rem center;appearance:none;-webkit-appearance:none}[data-theme=dark] .toolbar-search,[data-theme=dark] .toolbar-select{background-color:#1e1e1e;border-color:#ffffff14}[data-theme=dark] .toolbar-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239ca3af' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E")}.table-card{border-radius:14px;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 3px #00000008}.table-wrapper{max-height:580px}.admin-table{font-size:.88rem}.admin-table th{padding:.85rem 1.1rem;font-size:.68rem;letter-spacing:.07em;background:#f9fafb;border-bottom:1px solid rgba(0,0,0,.05);font-weight:700}.admin-table td{padding:.85rem 1.1rem;border-bottom:1px solid rgba(0,0,0,.04);vertical-align:middle}.admin-table tr:hover td{background:#16a34a06}[data-theme=dark] .table-card{background:#1e1e1e;border-color:#ffffff0f}[data-theme=dark] .admin-table th{background:#232323;border-bottom-color:#ffffff0f}[data-theme=dark] .admin-table td{border-bottom-color:#ffffff0a}[data-theme=dark] .admin-table tr:hover td{background:#16a34a0f}.user-cell{gap:.7rem}.table-avatar{width:36px;height:36px;border-radius:10px;font-size:.78rem;letter-spacing:-.01em;box-shadow:0 2px 6px #00000014}.user-cell-name{font-size:.9rem;font-weight:600;letter-spacing:-.01em}.user-cell-username{font-size:.74rem}.role-chip{padding:.22rem .7rem;border-radius:14px;font-size:.68rem;font-weight:700;letter-spacing:.05em;border:none}.role-student{background:#16a34a1f;color:#16a34a}.role-instructor{background:#f59e0b1f;color:#d97706}.role-admin{background:#ef44441f;color:#dc2626}[data-theme=dark] .role-student{background:#16a34a33;color:#4ade80}[data-theme=dark] .role-instructor{background:#f59e0b33;color:#fbbf24}[data-theme=dark] .role-admin{background:#ef444433;color:#fca5a5}.sortable-th{transition:color .15s ease,background .15s ease}.sortable-th:hover{background:#00000006}[data-theme=dark] .sortable-th:hover{background:#ffffff08}.sort-icon{margin-left:.35rem}.sort-icon.sort-active{color:#16a34a}.pagination{margin-top:1rem;padding:.7rem 1rem;border-radius:12px;border:1px solid rgba(0,0,0,.06);background:#fff;box-shadow:0 1px 3px #00000008}.page-btn{width:32px;height:32px;border-radius:8px;border:1px solid rgba(0,0,0,.08);background:#fff;color:var(--text-secondary, #4b5563);font-weight:600;font-size:.85rem;transition:all .15s ease}.page-btn:hover:not(:disabled):not(.active){border-color:#16a34a;color:#16a34a}.page-btn.active{background:#16a34a;border-color:#16a34a;color:#fff;box-shadow:0 2px 6px #16a34a52}.page-btn:disabled{opacity:.4;cursor:not-allowed}[data-theme=dark] .pagination{background:#1e1e1e;border-color:#ffffff0f}[data-theme=dark] .page-btn{background:#1e1e1e;border-color:#ffffff14}.create-user-section{display:flex;justify-content:center}.create-form-card{padding:1.75rem 2rem;border-radius:14px;background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 3px #00000008}.create-form-header{text-align:left;margin-bottom:1.25rem;padding-bottom:.85rem;border-bottom:1px solid rgba(0,0,0,.05)}.create-form-header h2{font-size:1.15rem;font-weight:800;letter-spacing:-.02em}.create-form-header p{font-size:.85rem;color:var(--text-muted, #9ca3af);margin-top:.2rem}.create-form-card .input-group{margin-bottom:1rem}.create-form-card .input-group label{display:block;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted, #9ca3af);margin-bottom:.4rem}.create-form-card .input-wrapper{border:1px solid rgba(0,0,0,.1);border-radius:10px;background:#fff;padding:0 .95rem;height:42px;transition:border-color .15s ease,box-shadow .15s ease}.create-form-card .input-wrapper:focus-within{border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1f}.create-form-card .input-wrapper svg{color:var(--text-muted, #9ca3af)}.create-form-card .input-wrapper:focus-within svg{color:#16a34a}.create-form-card .input-wrapper input,.create-form-card .input-wrapper select{font-size:.9rem;font-family:inherit;padding:0 0 0 .65rem;background:transparent;border:none;outline:none;width:100%;color:var(--text-primary, #1f2937)}[data-theme=dark] .create-form-card{background:#1e1e1e;border-color:#ffffff0f}[data-theme=dark] .create-form-header{border-bottom-color:#ffffff0d}[data-theme=dark] .create-form-card .input-wrapper{background:#232323;border-color:#ffffff1a}.create-form-card .btn-submit{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;width:100%;margin-top:.5rem;padding:.78rem 1.25rem;border:none;border-radius:10px;background:linear-gradient(135deg,#16a34a,#059669);color:#fff;font-family:inherit;font-size:.92rem;font-weight:700;cursor:pointer;transition:all .15s ease;box-shadow:0 3px 10px #16a34a4d}.create-form-card .btn-submit:before{display:none}.create-form-card .btn-submit:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #16a34a73;background:linear-gradient(135deg,#15803d,#047857)}.create-form-card .btn-submit:disabled{opacity:.55;cursor:not-allowed;box-shadow:none;transform:none}.action-btn-primary,.action-btn-outline,.action-btn-danger{padding:.45rem .85rem;border-radius:8px;font-family:inherit;font-size:.78rem;font-weight:700;cursor:pointer;transition:all .15s ease;border:1px solid transparent}.action-btn-primary{background:linear-gradient(135deg,#16a34a,#059669);color:#fff;border-color:transparent}.action-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 3px 10px #16a34a59}.action-btn-outline{background:#fff;color:var(--text-secondary, #4b5563);border-color:#0000001a}.action-btn-outline:hover{background:#00000008;border-color:#0000002e;color:var(--text-primary, #1f2937)}.action-btn-danger{background:#ef444414;color:#dc2626;border-color:#ef444433}.action-btn-danger:hover{background:#ef4444;color:#fff;border-color:#ef4444}[data-theme=dark] .action-btn-outline{background:#232323;border-color:#ffffff14;color:#d1d5db}[data-theme=dark] .action-btn-outline:hover{background:#2a2a2a}.editing-row td{background:#16a34a0a!important}.inline-edit-form{display:flex;flex-direction:column;gap:.5rem}.inline-edit-fields{display:flex;gap:.6rem;flex-wrap:wrap}.inline-edit-fields .input-group{margin:0}.inline-edit-fields .input-group input,.inline-edit-fields .input-group select,.inline-edit-fields .input-group textarea{width:100%;padding:.5rem .7rem;border:1px solid rgba(0,0,0,.1);border-radius:8px;background:#fff;font-family:inherit;font-size:.85rem;outline:none;transition:border-color .15s ease,box-shadow .15s ease}.inline-edit-fields .input-group input:focus,.inline-edit-fields .input-group select:focus,.inline-edit-fields .input-group textarea:focus{border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1f}[data-theme=dark] .inline-edit-fields .input-group input,[data-theme=dark] .inline-edit-fields .input-group select,[data-theme=dark] .inline-edit-fields .input-group textarea{background:#1e1e1e;border-color:#ffffff1a;color:#e5e7eb}.inline-edit-actions{display:flex;gap:.4rem;margin-top:.4rem}.admin-loading{padding:0}.table-skeleton{padding:1rem;display:flex;flex-direction:column;gap:.6rem;border-radius:14px;border:1px solid rgba(0,0,0,.06);background:#fff}.skeleton-row{height:50px;border-radius:8px;background:linear-gradient(90deg,#0000000a 25%,#00000014,#0000000a 75%);background-size:200% 100%;animation:adm-shimmer 1.4s infinite}@keyframes adm-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}[data-theme=dark] .table-skeleton{background:#1e1e1e;border-color:#ffffff0f}[data-theme=dark] .skeleton-row{background:linear-gradient(90deg,#ffffff0a 25%,#ffffff14,#ffffff0a 75%);background-size:200% 100%}.admin-empty,.user-empty{text-align:center;padding:3.5rem 1rem;color:var(--text-muted, #9ca3af);background:#fff;border:1px dashed rgba(0,0,0,.1);border-radius:14px}[data-theme=dark] .admin-empty,[data-theme=dark] .user-empty{background:#1e1e1e;border-color:#ffffff14}.glass{backdrop-filter:none!important;-webkit-backdrop-filter:none!important;background:#fff!important}.glow-border{box-shadow:0 1px 3px #00000008!important}[data-theme=dark] .glass{background:#1e1e1e!important}.admin-header-action{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border-radius:10px;background:linear-gradient(135deg,#16a34a,#059669);color:#fff;border:none;font-family:inherit;font-size:.86rem;font-weight:700;cursor:pointer;transition:all .15s ease;text-decoration:none;box-shadow:0 3px 10px #16a34a47}.admin-header-action:hover{transform:translateY(-1px);box-shadow:0 6px 16px #16a34a6b}.sms-wrapper{border:1px solid rgba(0,0,0,.1);border-radius:10px;background:#fff;transition:border-color .15s ease,box-shadow .15s ease}.sms-wrapper:focus-within{border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1f}.sms-search{border-bottom:1px solid rgba(0,0,0,.05);padding:.55rem .85rem}.sms-search-input{font-size:.86rem}.sms-count{background:#16a34a1a;color:#16a34a;padding:.2rem .6rem;border-radius:12px;font-size:.7rem;font-weight:700}.sms-chips{border-bottom:1px solid rgba(0,0,0,.05);padding:.55rem .55rem .3rem}.sms-chip{padding:.28rem .32rem .28rem .5rem;border-radius:14px;font-size:.74rem;font-weight:600;background:#16a34a1a;border-color:transparent;color:var(--text-primary, #1f2937)}.sms-chip-avatar{width:20px;height:20px;box-shadow:0 1px 3px #0000001f}.sms-chip-remove{width:16px;height:16px;background:#0000000f}.sms-options{max-height:240px;padding:.4rem}.sms-option{padding:.5rem .65rem;border-radius:8px;font-size:.85rem}.sms-option:hover,.sms-option-selected{background:#16a34a14}.sms-option input[type=checkbox]{accent-color:#16a34a;width:16px;height:16px}.sms-option-avatar{width:28px;height:28px;border-radius:8px;border:none}[data-theme=dark] .sms-wrapper{background:#1e1e1e;border-color:#ffffff1a}[data-theme=dark] .sms-search,[data-theme=dark] .sms-chips{border-bottom-color:#ffffff0f}[data-theme=dark] .sms-chip{background:#16a34a2e;color:#e5e7eb}[data-theme=dark] .sms-option:hover,[data-theme=dark] .sms-option-selected{background:#16a34a24}.course-cover{width:42px;height:42px;border-radius:10px;object-fit:cover;flex-shrink:0;box-shadow:0 2px 6px #00000014}.course-row-title{display:flex;align-items:center;gap:.7rem}.lesson-thumb{width:56px;height:32px;border-radius:6px;background:#1f2937;display:inline-flex;align-items:center;justify-content:center;color:#ffffffa6;flex-shrink:0}.confirm-dialog,.confirm-modal,.modal-card{border-radius:14px!important;border:1px solid rgba(0,0,0,.06)!important;box-shadow:0 20px 50px #0000002e!important;padding:1.5rem 1.6rem!important}.confirm-dialog h2,.confirm-modal h2,.modal-card h2{font-size:1.05rem!important;font-weight:800!important;letter-spacing:-.01em!important}[data-theme=dark] .confirm-dialog,[data-theme=dark] .confirm-modal,[data-theme=dark] .modal-card{background:#1e1e1e!important;border-color:#ffffff14!important}.profile-page{max-width:640px;margin:0 auto;padding:2.5rem 1.5rem}.profile-hero{display:flex;align-items:center;gap:1.25rem;padding:1.75rem;border-radius:var(--radius-lg);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.profile-hero-avatar{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#059669);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;box-shadow:0 4px 16px #16a34a40}.profile-hero-avatar img{width:100%;height:100%;object-fit:cover}.profile-hero-avatar span{font-size:1.75rem;font-weight:700;color:#fff}.profile-hero-info h1{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);margin:0 0 .15rem}.profile-hero-email{font-size:.875rem;color:var(--text-secondary);margin:0 0 .5rem}.profile-hero-role{display:inline-flex;padding:.2rem .65rem;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.profile-tabs{display:flex;gap:.25rem;padding:.3rem;border-radius:var(--radius-md);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);margin-bottom:1.5rem}.profile-tab{position:relative;flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.6rem .75rem;border:none;border-radius:var(--radius-sm);background:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:500;font-family:inherit;cursor:pointer;transition:color .2s ease;z-index:1}.profile-tab:hover{color:var(--text-primary)}.profile-tab.active{color:var(--accent);font-weight:600}.tab-indicator{position:absolute;inset:0;border-radius:var(--radius-sm);background:#16a34a0f;border:1px solid rgba(22,163,74,.15);z-index:-1}.profile-tab-content{min-height:300px}.profile-section{border-radius:var(--radius-lg);padding:1.75rem;background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm)}.section-head{margin-bottom:1.5rem}.section-head h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 .25rem}.section-head p{font-size:.85rem;color:var(--text-secondary);margin:0}.profile-section .input-row{display:flex;gap:.75rem}.profile-section .input-row .input-group{flex:1}.profile-section .input-group{margin-bottom:1.25rem}.profile-section .input-group label{display:block;margin-bottom:.4rem;font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em}.profile-section .input-wrapper{display:flex;align-items:center;gap:.6rem;padding:0 .85rem;border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-sm);background:#fff;transition:all .3s ease}.profile-section .input-wrapper svg{color:var(--text-muted);flex-shrink:0;transition:color .3s ease}.profile-section .input-wrapper:focus-within{border-color:var(--accent);background:#16a34a05;box-shadow:0 0 0 3px #16a34a14,0 2px 8px #16a34a0f}.profile-section .input-wrapper:focus-within svg{color:var(--accent)}.profile-section .input-wrapper input{width:100%;padding:.7rem 0;border:none;background:transparent;color:var(--text-primary);font-size:.925rem;font-family:inherit;outline:none}.profile-section .input-wrapper input::placeholder{color:var(--text-muted)}.textarea-wrapper{border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-sm);background:#fff;transition:all .3s ease}.textarea-wrapper:focus-within{border-color:var(--accent);background:#16a34a05;box-shadow:0 0 0 3px #16a34a14,0 2px 8px #16a34a0f}.textarea-wrapper textarea{width:100%;padding:.7rem .85rem;border:none;background:transparent;color:var(--text-primary);font-size:.925rem;font-family:inherit;outline:none;resize:vertical;min-height:80px}.textarea-wrapper textarea::placeholder{color:var(--text-muted)}.avatar-section{margin-bottom:1.25rem}.avatar-upload{display:flex;align-items:center;gap:1rem}.avatar-upload-info{display:flex;flex-direction:column;gap:.35rem}.avatar-hint{font-size:.75rem;color:var(--text-muted)}.avatar-preview{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#059669);display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 2px 12px #16a34a33}.avatar-preview img{width:100%;height:100%;object-fit:cover}.avatar-preview span{font-size:1.5rem;font-weight:700;color:#fff}.avatar-btn{display:inline-flex;padding:.45rem 1rem;border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-sm);background:#fff;color:var(--text-primary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s ease}.avatar-btn:hover{border-color:var(--accent);color:var(--accent);background:#16a34a0a}.btn-save{width:100%;padding:.75rem;border:none;border-radius:var(--radius-sm);background:linear-gradient(135deg,#16a34a,#059669);color:#fff;font-size:.95rem;font-weight:600;font-family:inherit;cursor:pointer;position:relative;overflow:hidden;transition:box-shadow .3s ease}.btn-save:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 40%,rgba(255,255,255,.15) 50%,transparent 60%);transform:translate(-100%);transition:transform .6s ease}.btn-save:hover:not(:disabled):before{transform:translate(100%)}.btn-save:hover:not(:disabled){box-shadow:0 4px 20px #16a34a4d,0 2px 8px #16a34a26}.btn-save:disabled{opacity:.6;cursor:not-allowed}.btn-save-warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.btn-save-warning:hover:not(:disabled){box-shadow:0 4px 20px #f59e0b4d,0 2px 8px #f59e0b26}.btn-loading{display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@media(max-width:640px){.profile-section .input-row{flex-direction:column;gap:0}.profile-hero{flex-direction:column;text-align:center}.profile-tabs{flex-direction:column}}[data-theme=dark] .profile-hero,[data-theme=dark] .profile-tabs{background:#161616;border-color:#ffffff0f}[data-theme=dark] .tab-indicator{background:#16a34a1a;border-color:#16a34a33}[data-theme=dark] .profile-section{background:#161616;border-color:#ffffff0f}[data-theme=dark] .profile-section .input-wrapper{border-color:#ffffff1a;background:#ffffff0a}[data-theme=dark] .profile-section .input-wrapper:focus-within{background:#16a34a0f}[data-theme=dark] .textarea-wrapper{border-color:#ffffff1a;background:#ffffff0a}[data-theme=dark] .textarea-wrapper:focus-within{background:#16a34a0f}[data-theme=dark] .avatar-btn{border-color:#ffffff1a;background:#ffffff0d;color:var(--text-primary)}[data-theme=dark] .avatar-btn:hover{background:#16a34a14}.courses-container{max-width:960px;margin:0 auto;padding:2.5rem 1.5rem}.courses-container--wide{max-width:1060px}.courses-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.courses-header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .25rem;color:var(--text-primary)}.courses-subtitle{color:var(--text-secondary);font-size:.9rem;margin:0}.course-cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}@media(max-width:700px){.course-cards-grid{grid-template-columns:1fr}}.course-card-v2{position:relative;background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:16px;overflow:hidden;cursor:pointer;box-shadow:0 1px 4px #0000000a,0 6px 20px #0000000a;transition:box-shadow .3s ease,border-color .3s ease}.course-card-v2:hover{box-shadow:0 8px 24px #00000014,0 20px 40px #0000000f;border-color:#16a34a33}.course-card-v2-banner{position:relative;width:100%;height:160px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#059669,#34d399)}.course-card-v2-banner-img{width:100%;height:100%;object-fit:cover}.course-card-v2-banner-icon{width:64px;height:64px;border-radius:20px;background:#fff3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;color:#fff}.course-card-v2-banner-badge{position:absolute;bottom:10px;right:10px;display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;font-weight:700;color:#fff;background:#00000073;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);padding:.3rem .65rem;border-radius:8px}.course-card-v2-body{padding:1.15rem 1.25rem 1.1rem}.course-card-v2-title{font-size:1.05rem;font-weight:700;color:var(--text-primary);margin:0 0 .35rem;letter-spacing:-.01em;line-height:1.35;display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.course-card-v2-desc{font-size:.82rem;color:var(--text-secondary);margin:0 0 .85rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.course-card-v2-footer{display:flex;align-items:center;justify-content:space-between}.course-card-v2-date{font-size:.7rem;color:var(--text-muted)}.course-card-v2-cta{display:inline-flex;align-items:center;gap:.25rem;font-size:.78rem;font-weight:600;color:var(--accent);opacity:0;transform:translate(-4px);transition:opacity .25s ease,transform .25s ease}.course-card-v2:hover .course-card-v2-cta{opacity:1;transform:translate(0)}.course-card-skeleton{display:flex;flex-direction:column;gap:.75rem;padding:0;border-radius:16px;background:#fff;border:1px solid rgba(0,0,0,.06);overflow:hidden}.course-card-skeleton .skeleton-row:first-child{margin:0;border-radius:0}.course-detail-card{border-radius:var(--radius-lg);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);padding:2rem}.course-detail-title{font-size:1.5rem;font-weight:700;letter-spacing:-.01em;color:var(--text-primary);margin:0 0 .35rem}.course-detail-date{font-size:.8rem;color:var(--text-muted);margin:0 0 1.5rem}.course-detail-logo-wrap{margin-bottom:1.5rem}.course-detail-logo{max-width:180px;max-height:120px;object-fit:contain;border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.06)}.course-detail-section{margin-bottom:1.5rem}.course-detail-section h3{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin:0 0 .5rem;display:flex;align-items:center;gap:.5rem}.course-detail-section h3:before{content:"";width:4px;height:1.125rem;background:linear-gradient(180deg,#16a34a,#22c55e);border-radius:2px}.course-detail-section p{font-size:.95rem;color:var(--text-secondary);margin:0;line-height:1.6;white-space:pre-wrap}.course-actions{display:flex;gap:.5rem;margin-top:2rem;padding-top:1.5rem;border-top:1px solid rgba(0,0,0,.06)}.course-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border-radius:var(--radius-sm);font-size:.82rem;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:all .2s ease}.course-btn-edit{background:#16a34a14;color:var(--accent);border:1px solid rgba(22,163,74,.2)}.course-btn-edit:hover{background:#16a34a24}.course-btn-delete{background:#ef444414;color:#dc2626;border:1px solid rgba(239,68,68,.2)}.course-btn-delete:hover{background:#ef444424}.course-btn-cancel{background:transparent;color:var(--text-secondary);border:1px solid rgba(0,0,0,.1)}.course-btn-cancel:hover{background:var(--bg-secondary)}.course-btn-save{background:var(--accent);color:#fff;border:1px solid var(--accent)}.course-btn-save:hover{opacity:.9}.course-btn-save:disabled,.course-btn-delete:disabled{opacity:.5;cursor:not-allowed}.course-confirm-row{display:flex;align-items:center;gap:.5rem}.course-confirm-text{font-size:.82rem;font-weight:600;color:#dc2626}.course-confirm-input{min-width:180px;padding:.45rem .6rem;border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.15);background:var(--bg-secondary);color:var(--text-primary);font-size:.85rem}.course-confirm-input:focus{outline:none;border-color:#dc2626;box-shadow:0 0 0 3px #dc26261f}.course-edit-form{display:flex;flex-direction:column;gap:1rem}.course-edit-form .input-group label{display:block;font-size:.78rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:.35rem}.course-edit-form .input-group input,.course-edit-form .input-group textarea{width:100%;padding:.6rem .85rem;border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-sm);background:var(--bg-secondary);color:var(--text-primary);font-size:.9rem;font-family:inherit;outline:none;transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.course-edit-form .input-group textarea{min-height:120px;resize:vertical}.course-edit-form .input-group input:focus,.course-edit-form .input-group textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #16a34a14}.course-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.course-empty h2{font-size:1.1rem;margin:0 0 .5rem;color:var(--text-secondary)}.course-empty p{font-size:.85rem;margin:0}.logo-file-input{display:none}.logo-upload-area{margin-top:.25rem}.logo-upload-label{display:flex;align-items:center;gap:.5rem;padding:.85rem 1.25rem;border:2px dashed rgba(0,0,0,.12);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.85rem;cursor:pointer;transition:border-color .2s ease,color .2s ease,background .2s ease}.logo-upload-label:hover{border-color:var(--accent);color:var(--accent);background:#16a34a08}.logo-preview-wrap{position:relative;display:inline-block}.logo-preview-img{max-width:140px;max-height:90px;object-fit:contain;border-radius:var(--radius-sm);border:1px solid rgba(0,0,0,.08)}.logo-remove-btn{position:absolute;top:-6px;right:-6px;width:22px;height:22px;display:flex;align-items:center;justify-content:center;padding:0;border:none;border-radius:50%;background:#ef4444e6;color:#fff;cursor:pointer;transition:background .15s ease}.logo-remove-btn:hover{background:#dc2626}.lesson-list{display:flex;flex-direction:column;gap:.75rem}.lesson-card{padding:1.15rem 1.25rem;border-radius:var(--radius-lg);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);cursor:pointer;transition:all .2s ease}.lesson-card:hover{border-color:#16a34a4d;box-shadow:0 4px 16px #16a34a1a}.lesson-card-header{display:flex;align-items:flex-start;gap:.85rem;width:100%}.lesson-card-order{flex-shrink:0;font-size:.72rem;font-weight:700;font-family:SF Mono,Fira Code,monospace;color:var(--text-muted);padding-top:.1rem}.lesson-card-body{flex:1;min-width:0}.lesson-card-title{font-weight:600;font-size:.95rem;color:var(--text-primary)}.lesson-card-content{font-size:.82rem;color:var(--text-muted);margin:.3rem 0 0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.lesson-card-meta{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.lesson-card-chip{font-size:.72rem;font-weight:600;color:var(--text-secondary);background:#16a34a1a;padding:.2rem .55rem;border-radius:999px}.lesson-card-link{font-size:.72rem;font-weight:600;color:var(--accent);text-decoration:none;border:1px solid rgba(22,163,74,.2);padding:.2rem .55rem;border-radius:999px}.lesson-card-link:hover{background:#16a34a14}.lesson-create-card{padding:1.25rem;border-radius:var(--radius-lg);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm)}.lesson-detail-card{background:linear-gradient(160deg,#fffffffa,#fff);border:1.5px solid rgba(22,163,74,.18);border-radius:calc(var(--radius-lg) + 4px);padding:2rem;box-shadow:0 8px 24px #0f172a14}.lesson-video-wrapper{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:12px;background:#0000000d;box-shadow:0 4px 16px #0000001f}.lesson-video-wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%;border-radius:12px;border:none}[data-theme=dark] .course-card-v2{background:var(--bg-primary);border-color:#ffffff0f;box-shadow:0 1px 4px #0003,0 6px 20px #00000026}[data-theme=dark] .course-card-v2:hover{border-color:#22c55e4d;box-shadow:0 8px 24px #00000040,0 20px 40px #22c55e0f}[data-theme=dark] .course-card-v2-banner-icon{background:#ffffff26}[data-theme=dark] .course-card-v2-cta{color:#22c55e}[data-theme=dark] .course-card-skeleton{background:var(--bg-primary);border-color:#ffffff0f}[data-theme=dark] .course-detail-card{background:linear-gradient(160deg,#0f172af2,#0f172ad1);border-color:#22c55e2e}[data-theme=dark] .course-detail-section h3:before{background:linear-gradient(180deg,#94a3b8,#cbd5e1)}[data-theme=dark] .course-actions{border-top-color:#ffffff0f}[data-theme=dark] .lesson-card,[data-theme=dark] .lesson-create-card{background:var(--bg-primary);border-color:#ffffff0f}[data-theme=dark] .lesson-card:hover{border-color:#22c55e4d;box-shadow:0 4px 16px #22c55e0f}[data-theme=dark] .lesson-card-link{border-color:#22c55e4d}[data-theme=dark] .lesson-detail-card{background:linear-gradient(160deg,#1e293bf2,#0f172afa);border-color:#94a3b826;box-shadow:0 8px 24px #0000004d}[data-theme=dark] .lesson-video-wrapper{background:#0006;box-shadow:0 4px 16px #0000004d}[data-theme=dark] .logo-upload-label{border-color:#ffffff1a}[data-theme=dark] .logo-upload-label:hover{border-color:var(--accent);background:#16a34a0f}[data-theme=dark] .logo-preview-img{border-color:#ffffff14}@media(max-width:640px){.courses-container{padding:1.5rem 1rem}.course-card-v2-body{padding:1rem}.course-card-v2-banner{height:130px}}.course-detail-page{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.course-detail-page .breadcrumb{display:flex;align-items:center;gap:.5rem;margin-bottom:2rem;font-size:.875rem}.course-detail-page .breadcrumb-link{color:var(--text-secondary);text-decoration:none;transition:color .2s}.course-detail-page .breadcrumb-link:hover{color:var(--accent)}.course-detail-page .breadcrumb-separator{color:var(--text-muted)}.course-detail-page .breadcrumb-current{color:var(--text-primary);font-weight:500}.course-hero{margin-bottom:2.5rem}.course-hero-content{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;flex-wrap:wrap}.course-hero-left{display:flex;gap:1.5rem;align-items:flex-start;flex:1;min-width:300px}.course-hero-logo{width:120px;height:120px;border-radius:16px;object-fit:cover;box-shadow:0 8px 24px #0000001f;flex-shrink:0}.course-hero h1{font-size:2.5rem;font-weight:700;margin:0 0 1rem;color:var(--text-primary);line-height:1.2}.course-hero-description{font-size:1.125rem;color:var(--text-secondary);margin:0 0 1.5rem;line-height:1.6}.course-meta{display:flex;flex-wrap:wrap;gap:1.5rem;align-items:center}.course-meta-item{display:flex;align-items:center;gap:.5rem;font-size:.95rem;color:var(--text-secondary)}.course-price-badge{padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.95rem}.course-price-badge.free{background:#22c55e1a;color:#22c55e}.course-price-badge.paid{background:#3b82f61a;color:#3b82f6}.course-status-badge{padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.875rem}.course-status-badge.purchased{background:#22c55e1a;color:#22c55e}.course-hero-actions{display:flex;flex-direction:column;gap:.75rem;min-width:200px}.btn-lg{padding:.875rem 1.75rem;font-size:1rem;font-weight:600}.course-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2.5rem}.stat-card{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 2px 8px #0000000a;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #00000014}.stat-icon{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,var(--accent),#059669);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:.25rem}.stat-label{font-size:.875rem;color:var(--text-muted)}.course-about{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px #0000000a}.course-about h2{font-size:1.5rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary)}.course-about p{color:var(--text-secondary);line-height:1.8;margin:0 0 1.5rem}.course-cta{padding-top:1.5rem;border-top:1px solid rgba(0,0,0,.06);text-align:center}.course-cta p{font-size:1.125rem;font-weight:500;margin:0 0 1rem;color:var(--text-primary)}.course-navigation{padding-top:2rem;border-top:1px solid rgba(0,0,0,.06)}.course-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 1rem;text-align:center}.spinner{width:40px;height:40px;border:3px solid rgba(0,0,0,.1);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}[data-theme=dark] .stat-card,[data-theme=dark] .course-about{background:#ffffff08;border-color:#ffffff14}[data-theme=dark] .course-cta,[data-theme=dark] .course-navigation{border-top-color:#ffffff14}@media(max-width:768px){.course-detail-page{padding:1.5rem 1rem}.course-hero h1{font-size:1.875rem}.course-hero-left{flex-direction:column}.course-hero-logo{width:100px;height:100px}.course-stats-grid{grid-template-columns:1fr}.course-meta{flex-direction:column;align-items:flex-start;gap:.75rem}}.cl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:.5rem}.cl-card{display:flex;flex-direction:column;gap:.5rem;padding:1.2rem 1.3rem 1rem;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:14px;cursor:pointer;transition:border-color .18s ease,box-shadow .18s ease;position:relative;box-shadow:0 1px 3px #00000008}.cl-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;border-radius:14px 14px 0 0;background:var(--accent);opacity:.85}.cl-card:hover{border-color:var(--accent);box-shadow:0 6px 22px color-mix(in srgb,var(--accent) 18%,transparent)}.cl-card-locked{opacity:.85}.cl-card-icon{width:42px;height:42px;border-radius:11px;display:inline-flex;align-items:center;justify-content:center;color:#fff;margin-bottom:.2rem;flex-shrink:0;box-shadow:0 4px 10px color-mix(in srgb,var(--accent) 30%,transparent)}.cl-card-icon img{width:100%;height:100%;object-fit:cover;border-radius:11px}.cl-card-title{margin:0;font-size:1.05rem;font-weight:700;letter-spacing:-.01em;color:var(--text-primary, #1f2937);line-height:1.3}.cl-card-desc{margin:0;font-size:.84rem;color:var(--text-secondary, #4b5563);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.cl-card-meta{display:flex;flex-wrap:wrap;gap:.35rem;margin:.35rem 0}.cl-meta-pill{display:inline-flex;align-items:center;gap:.3rem;padding:.22rem .6rem;border-radius:14px;background:#0000000d;color:var(--text-secondary, #4b5563);font-size:.72rem;font-weight:600}.cl-meta-owned{background:#16a34a1f;color:#16a34a}.cl-meta-free{background:#22c55e1f;color:#16a34a}.cl-meta-price{background:#f59e0b1f;color:#d97706}.cl-card-cta{display:inline-flex;align-items:center;gap:.3rem;font-size:.83rem;font-weight:700;margin-top:auto;padding-top:.4rem}[data-theme=dark] .cl-card{background:#1e1e1e;border-color:#ffffff0f}[data-theme=dark] .cl-meta-pill{background:#ffffff0f}.cd-page{max-width:760px;margin:0 auto;padding:1.5rem 1.25rem 3rem}.cd-back{display:inline-flex;align-items:center;gap:.4rem;font-size:.84rem;color:var(--text-secondary, #6b7280);text-decoration:none;margin-bottom:1rem;font-weight:500;transition:color .15s ease}.cd-back:hover{color:#16a34a}.cd-hero{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:16px;padding:1.6rem 1.8rem;box-shadow:0 1px 3px #00000008}.cd-logo{width:56px;height:56px;border-radius:12px;object-fit:cover;margin-bottom:.85rem}.cd-title{margin:0 0 .5rem;font-size:1.7rem;font-weight:800;letter-spacing:-.02em;color:var(--text-primary, #1f2937);line-height:1.2}.cd-description{margin:0 0 1rem;font-size:.95rem;line-height:1.55;color:var(--text-secondary, #4b5563)}.cd-meta{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.25rem}.cd-meta-item{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .7rem;border-radius:14px;background:#0000000a;color:var(--text-secondary, #4b5563);font-size:.78rem;font-weight:600}.cd-meta-owned{background:#16a34a1f;color:#16a34a}.cd-meta-free{background:#22c55e1f;color:#16a34a}.cd-meta-price{background:#f59e0b1f;color:#d97706}.cd-actions{display:flex;gap:.6rem;flex-wrap:wrap}.cd-btn-primary{flex:1;min-width:200px;padding:.8rem 1.4rem;border:none;border-radius:10px;background:linear-gradient(135deg,#16a34a,#059669);color:#fff;font-family:inherit;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .15s ease;box-shadow:0 4px 12px #16a34a4d}.cd-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px #16a34a6b;background:linear-gradient(135deg,#15803d,#047857)}.cd-btn-primary:disabled{opacity:.55;cursor:not-allowed;background:#9ca3af;box-shadow:none}.cd-btn-ghost{padding:.8rem 1.2rem;border:1px solid rgba(0,0,0,.1);border-radius:10px;background:#fff;color:var(--text-primary, #1f2937);font-family:inherit;font-size:.92rem;font-weight:600;cursor:pointer;transition:all .15s ease}.cd-btn-ghost:hover{background:#00000008;border-color:#0003}[data-theme=dark] .cd-hero{background:#1e1e1e;border-color:#ffffff0f}[data-theme=dark] .cd-meta-item{background:#ffffff0d}[data-theme=dark] .cd-btn-ghost{background:#1e1e1e;border-color:#ffffff14}@media(max-width:600px){.cd-page{padding:1rem 1rem 2rem}.cd-hero{padding:1.2rem 1.3rem}.cd-title{font-size:1.4rem}.cd-actions{flex-direction:column}.cd-btn-primary{width:100%;min-width:0}}.course-lessons-page,.lesson-detail-page{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.breadcrumb{display:flex;align-items:center;gap:.5rem;margin-bottom:2rem;font-size:.875rem}.breadcrumb-link{color:var(--text-secondary);text-decoration:none;transition:color .2s}.breadcrumb-link:hover{color:var(--accent)}.breadcrumb-separator{color:var(--text-muted)}.breadcrumb-current{color:var(--text-primary);font-weight:500}.course-lessons-header{margin-bottom:2.5rem}.course-header-content{display:flex;justify-content:space-between;align-items:flex-start;gap:2rem;flex-wrap:wrap}.course-header-left{display:flex;gap:1.5rem;align-items:flex-start;flex:1}.course-header-logo{width:80px;height:80px;border-radius:12px;object-fit:cover;box-shadow:0 4px 12px #0000001a}.course-header-content h1{font-size:2rem;font-weight:700;margin:0 0 .5rem;color:var(--text-primary)}.course-description{color:var(--text-secondary);margin:0;line-height:1.6}.course-header-actions{display:flex;gap:.75rem;flex-wrap:wrap}.lessons-container{margin-top:2rem}.lessons-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.lessons-header h2{font-size:1.5rem;font-weight:600;margin:0;color:var(--text-primary)}.lessons-count{font-size:.875rem;color:var(--text-muted);background:var(--bg-secondary);padding:.4rem .8rem;border-radius:20px}.lessons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.lesson-card{cursor:pointer;padding:1.5rem;transition:all .3s ease;border:1px solid rgba(0,0,0,.08)}.lesson-card:hover{box-shadow:0 8px 24px #0000001f}.lesson-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.lesson-number{font-size:.75rem;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:.5px}.lesson-video-badge{display:flex;align-items:center;gap:.3rem;font-size:.75rem;color:#ef4444;background:#ef44441a;padding:.3rem .6rem;border-radius:20px}.lesson-title{font-size:1.125rem;font-weight:600;margin:0 0 .75rem;color:var(--text-primary);line-height:1.4}.lesson-preview{font-size:.875rem;color:var(--text-secondary);line-height:1.6;margin:0 0 1rem}.lesson-card-footer{display:flex;justify-content:space-between;align-items:center;padding-top:1rem;border-top:1px solid rgba(0,0,0,.06)}.lesson-date{font-size:.75rem;color:var(--text-muted)}.lesson-cta{display:flex;align-items:center;gap:.3rem;font-size:.875rem;font-weight:500;color:var(--accent)}.lesson-header{margin-bottom:2rem}.lesson-header-content h1{font-size:2.25rem;font-weight:700;margin:0 0 1rem;color:var(--text-primary);line-height:1.2}.lesson-meta{display:flex;gap:1.5rem;flex-wrap:wrap}.lesson-meta-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.lesson-video-section{margin-bottom:2rem}.video-container{position:relative;width:100%;padding-bottom:56.25%;background:#000;border-radius:12px;overflow:hidden}.video-container iframe{position:absolute;top:0;left:0;width:100%;height:100%}.lesson-content-section{margin-bottom:2rem}.lesson-content-section h2,.lesson-homework-section h2{font-size:1.5rem;font-weight:600;margin:0 0 1.5rem;color:var(--text-primary)}.lesson-content{line-height:1.8;color:var(--text-primary)}.lesson-content p{margin-bottom:1rem}.lesson-content h1,.lesson-content h2,.lesson-content h3{margin-top:1.5rem;margin-bottom:.75rem}.lesson-content ul,.lesson-content ol{margin-left:1.5rem;margin-bottom:1rem}.lesson-content code{background:var(--bg-secondary);padding:.2rem .4rem;border-radius:4px;font-size:.875em}.lesson-content pre{background:var(--bg-secondary);padding:1rem;border-radius:8px;overflow-x:auto;margin-bottom:1rem}.lesson-homework-section{margin-bottom:2rem}.homework-list{display:grid;gap:1rem}.homework-item{padding:1.5rem;background:var(--bg-secondary);border-radius:12px;border:1px solid rgba(0,0,0,.06)}.homework-item-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.homework-item-header h3{font-size:1.125rem;font-weight:600;margin:0;color:var(--text-primary)}.homework-points{font-size:.875rem;font-weight:600;color:var(--accent);background:rgba(var(--accent-rgb),.1);padding:.3rem .8rem;border-radius:20px}.homework-description{color:var(--text-secondary);margin:0 0 .75rem;line-height:1.6}.homework-due{font-size:.875rem;color:var(--text-muted);margin:0 0 1rem}.homework-status{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;font-size:.875rem}.status-badge{padding:.25rem .6rem;border-radius:12px;font-weight:500;font-size:.75rem;text-transform:capitalize}.status-draft{background:#9ca3af1a;color:#6b7280}.status-submitted{background:#3b82f61a;color:#3b82f6}.status-graded{background:#22c55e1a;color:#22c55e}.homework-score{font-weight:600;color:var(--text-primary)}.lesson-navigation{display:flex;justify-content:space-between;margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(0,0,0,.06)}.lessons-loading,.lesson-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 1rem;text-align:center}.spinner{width:40px;height:40px;border:3px solid rgba(0,0,0,.1);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.lessons-empty{text-align:center;padding:4rem 2rem}.lessons-empty svg{color:var(--text-muted);margin-bottom:1rem}.lessons-empty h3{font-size:1.25rem;font-weight:600;margin:0 0 .5rem;color:var(--text-primary)}.lessons-empty p{color:var(--text-secondary);margin:0}.btn-primary,.btn-secondary{padding:.625rem 1.25rem;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s;border:none;text-decoration:none;display:inline-block}.btn-primary{background:linear-gradient(135deg,var(--accent),#059669);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(var(--accent-rgb),.3)}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid rgba(0,0,0,.08)}.btn-secondary:hover{background:#0000000d}[data-theme=dark] .lesson-card,[data-theme=dark] .homework-item{background:#ffffff08;border-color:#ffffff14}[data-theme=dark] .lesson-card-footer,[data-theme=dark] .lesson-navigation{border-top-color:#ffffff14}[data-theme=dark] .video-container{background:#1a1a1a}@media(max-width:768px){.course-lessons-page,.lesson-detail-page{padding:1.5rem 1rem}.course-header-content,.course-header-left{flex-direction:column}.lessons-grid{grid-template-columns:1fr}.lesson-header-content h1{font-size:1.75rem}.lesson-meta{flex-direction:column;gap:.75rem}}.lp-page{display:flex;flex-direction:column;height:calc(100vh - 1rem);max-height:calc(100vh - 1rem);overflow:hidden;background:var(--bg-primary, #f7f8fa)}.lp-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.85rem;padding:6rem 1rem;color:var(--text-muted, #9ca3af)}.lp-spinner{width:32px;height:32px;border-radius:50%;border:3px solid rgba(22,163,74,.18);border-top-color:#16a34a;animation:lp-spin .8s linear infinite}@keyframes lp-spin{to{transform:rotate(360deg)}}.lp-topbar{display:flex;justify-content:space-between;align-items:center;gap:.85rem;padding:.7rem 1.2rem;background:#fff;border-bottom:1px solid rgba(0,0,0,.06);flex-shrink:0}.lp-topbar-left{display:flex;align-items:center;gap:.6rem;min-width:0}.lp-toggle{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid rgba(0,0,0,.08);border-radius:7px;background:#fff;color:var(--text-secondary, #6b7280);cursor:pointer;transition:all .15s ease;flex-shrink:0}.lp-toggle:hover{background:#0000000a;color:var(--text-primary, #1f2937)}.lp-crumb{font-size:.85rem;color:var(--text-secondary, #6b7280);text-decoration:none;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .15s ease}.lp-crumb:hover{color:#16a34a}.lp-crumb-sep{color:var(--text-muted, #9ca3af);font-size:.85rem;flex-shrink:0}.lp-progress{font-size:.78rem;color:var(--text-muted, #9ca3af);font-weight:600;font-variant-numeric:tabular-nums}[data-theme=dark] .lp-topbar{background:#1a1a1a;border-bottom-color:#ffffff0f}[data-theme=dark] .lp-toggle{background:#1e1e1e;border-color:#ffffff14}.lp-body{flex:1;display:flex;min-height:0;overflow:hidden;position:relative}.lp-sidebar{width:320px;flex-shrink:0;background:#fff;border-right:1px solid rgba(0,0,0,.06);display:flex;flex-direction:column;overflow:hidden}.lp-sidebar-head{display:flex;justify-content:space-between;align-items:center;padding:.85rem 1.1rem;border-bottom:1px solid rgba(0,0,0,.05);flex-shrink:0}.lp-sidebar-title{margin:0;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted, #6b7280)}.lp-sidebar-count{font-size:.7rem;font-weight:700;padding:.15rem .55rem;border-radius:10px;background:#16a34a1a;color:#16a34a}.lp-lesson-list{flex:1;overflow-y:auto;padding:.45rem;display:flex;flex-direction:column;gap:2px}.lp-lesson-list::-webkit-scrollbar{width:6px}.lp-lesson-list::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}.lp-lesson-item{display:flex;align-items:center;gap:.65rem;padding:.65rem .75rem;border-radius:8px;text-decoration:none;color:var(--text-secondary, #4b5563);font-size:.86rem;line-height:1.35;transition:background .15s ease,color .15s ease}.lp-lesson-item:hover{background:#16a34a0f;color:var(--text-primary, #1f2937)}.lp-lesson-item.active{background:linear-gradient(135deg,#16a34a1f,#0891b214);color:#16a34a;font-weight:600}.lp-lesson-item.active .lp-lesson-num{background:#16a34a;color:#fff}.lp-lesson-num{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:7px;background:#0000000d;color:var(--text-muted, #9ca3af);font-size:.74rem;font-weight:700;flex-shrink:0;font-variant-numeric:tabular-nums;transition:all .15s ease}.lp-lesson-title{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lp-lesson-icon{color:var(--text-muted, #9ca3af);flex-shrink:0}[data-theme=dark] .lp-sidebar{background:#1a1a1a;border-right-color:#ffffff0f}[data-theme=dark] .lp-sidebar-head{border-bottom-color:#ffffff0d}[data-theme=dark] .lp-lesson-item:hover{background:#16a34a1f}[data-theme=dark] .lp-lesson-num{background:#ffffff0f}.lp-main{flex:1;min-width:0;overflow-y:auto;padding:1.5rem clamp(1rem,4vw,2.5rem) 2rem}.lp-main::-webkit-scrollbar{width:8px}.lp-main::-webkit-scrollbar-thumb{background:#0000002e;border-radius:4px}.lp-title-row{margin-bottom:1rem}.lp-title{margin:0;font-size:1.6rem;font-weight:800;letter-spacing:-.02em;color:var(--text-primary, #1f2937)}.lp-video-wrap{position:relative;width:100%;padding-top:56.25%;background:#000;border-radius:14px;overflow:hidden;box-shadow:0 8px 24px #0000002e;margin-bottom:1.25rem}.lp-video-wrap iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}.lp-no-video{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.5rem;padding:4rem 1rem;background:#0000000a;border-radius:12px;color:var(--text-muted, #9ca3af);margin-bottom:1.25rem;font-size:.88rem}[data-theme=dark] .lp-no-video{background:#ffffff0a}.lp-content-card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:12px;padding:1.2rem 1.35rem;margin-bottom:1.25rem;box-shadow:0 1px 3px #00000008}.lp-section-title{margin:0 0 .75rem;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted, #6b7280)}.lp-content{font-size:.95rem;line-height:1.65;color:var(--text-primary, #1f2937)}.lp-content p{margin:0 0 .75rem}[data-theme=dark] .lp-content-card{background:#1e1e1e;border-color:#ffffff0f}.lp-nav{display:flex;gap:.75rem;margin-top:1rem}.lp-nav-btn{flex:1;display:flex;align-items:center;gap:.7rem;padding:.85rem 1.1rem;border:1px solid rgba(0,0,0,.08);border-radius:10px;background:#fff;color:var(--text-primary, #1f2937);font-family:inherit;cursor:pointer;transition:all .15s ease;text-align:left;min-width:0}.lp-nav-btn:hover:not(:disabled){border-color:#16a34a;background:#16a34a0a;transform:translateY(-1px);box-shadow:0 4px 12px #16a34a1f}.lp-nav-btn:disabled{opacity:.45;cursor:not-allowed}.lp-nav-next{flex-direction:row-reverse;text-align:right}.lp-nav-text{display:flex;flex-direction:column;flex:1;min-width:0}.lp-nav-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted, #9ca3af)}.lp-nav-sub{font-size:.86rem;font-weight:600;margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}[data-theme=dark] .lp-nav-btn{background:#1e1e1e;border-color:#ffffff14}@media(max-width:820px){.lp-sidebar{position:absolute;left:0;top:0;bottom:0;z-index:20;width:280px;box-shadow:4px 0 20px #00000026}.lp-progress{display:none}}.mygroups-page{max-width:760px;margin:0 auto;padding:2.5rem 1.5rem}.mygroups-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem}.mygroups-header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .25rem;color:var(--text-primary)}.mygroups-subtitle{color:var(--text-secondary);font-size:.9rem;margin:0}.mygroups-count-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;background:#16a34a14;color:var(--accent);font-size:.85rem;font-weight:600;border:1px solid rgba(22,163,74,.15)}.mygroups-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}.mygroups-loading p{color:var(--text-secondary);font-size:.9rem}.mygroups-spinner{width:32px;height:32px;border:3px solid rgba(22,163,74,.15);border-top-color:var(--accent);border-radius:50%;animation:mgSpin .7s linear infinite}@keyframes mgSpin{to{transform:rotate(360deg)}}.mygroups-empty{text-align:center;padding:4rem 2rem;border-radius:var(--radius-lg);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm)}.mygroups-empty-icon{display:inline-flex;padding:1.25rem;border-radius:50%;background:#16a34a14;color:var(--accent);margin-bottom:1.25rem}.mygroups-empty h3{font-size:1.15rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.mygroups-empty p{color:var(--text-secondary);font-size:.9rem;max-width:360px;margin:0 auto}.mygroups-list{display:flex;flex-direction:column;gap:.75rem}.mygroup-card{border-radius:var(--radius-lg);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);overflow:hidden;transition:border-color .2s ease,box-shadow .2s ease}.mygroup-card.expanded{border-color:#16a34a33;box-shadow:0 4px 16px #16a34a14}.mygroup-card-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1.25rem 1.5rem;border:none;background:transparent;cursor:pointer;font-family:inherit;text-align:left;transition:background .15s ease}.mygroup-card-header:hover{background:#16a34a05}.mygroup-info{display:flex;align-items:center;gap:1rem}.mygroup-icon{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,#16a34a1a,#05966914);display:flex;align-items:center;justify-content:center;color:var(--accent);flex-shrink:0}.mygroup-info h3{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin:0}.mygroup-desc{font-size:.8rem;color:var(--text-secondary);margin:.15rem 0 0}.mygroup-meta{display:flex;align-items:center;gap:.75rem}.mygroup-member-count,.mygroup-course-count{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-secondary);font-weight:500}.mygroup-chevron{color:var(--text-muted)}.mygroup-body{overflow:hidden}.mygroup-body-inner{padding:0 1.5rem 1.5rem;border-top:1px solid rgba(0,0,0,.05)}.mygroup-section{margin-top:1.25rem}.mygroup-section-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.mygroup-section-title{display:flex;align-items:center;gap:.5rem;font-size:.8rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin:0 0 .75rem}.section-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:#16a34a1a;color:var(--accent);font-size:.7rem;font-weight:700}.mygroup-search{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border:1px solid rgba(0,0,0,.08);border-radius:var(--radius-sm);background:#00000005;transition:all .2s ease;margin-bottom:.75rem}.mygroup-search:focus-within{border-color:var(--accent);background:#16a34a05;box-shadow:0 0 0 3px #16a34a14}.mygroup-search svg{color:var(--text-muted);flex-shrink:0}.mygroup-search input{border:none;background:transparent;color:var(--text-primary);font-size:.85rem;font-family:inherit;outline:none;width:160px}.mygroup-search input::placeholder{color:var(--text-muted)}.mygroup-members-list{display:flex;flex-direction:column;gap:2px}.mygroup-member{display:flex;align-items:center;gap:.75rem;padding:.7rem .85rem;border-radius:var(--radius-sm);text-decoration:none;color:inherit;transition:background .15s ease}.mygroup-member:hover{background:#16a34a0a}.mygroup-member.instructor-member{background:#f59e0b0a;border:1px solid rgba(245,158,11,.1);border-radius:var(--radius-sm)}.mygroup-member.instructor-member:hover{background:#f59e0b14}.member-avatar{width:38px;height:38px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#059669);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.member-avatar img{width:100%;height:100%;object-fit:cover}.member-info{flex:1;min-width:0}.member-name{display:block;font-size:.9rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-email{display:block;font-size:.78rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-role-badge{display:inline-flex;padding:.15rem .55rem;border-radius:12px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;flex-shrink:0}.member-you-badge{display:inline-flex;padding:.15rem .55rem;border-radius:12px;font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;background:#16a34a1a;color:var(--accent);border:1px solid rgba(22,163,74,.2);flex-shrink:0}.member-arrow{color:var(--text-muted);flex-shrink:0;transition:transform .15s ease}.mygroup-member:hover .member-arrow{transform:translate(2px);color:var(--accent)}.mygroup-no-students,.mygroup-no-results{font-size:.85rem;color:var(--text-muted);padding:.75rem 0;margin:0;text-align:center}.mygroup-courses-list{display:flex;flex-direction:column;gap:2px}.mygroup-course{display:flex;align-items:center;gap:.75rem;padding:.7rem .85rem;border-radius:var(--radius-sm);text-decoration:none;color:inherit;transition:background .15s ease}.mygroup-course:hover{background:#16a34a0a}.course-thumb{width:42px;height:42px;border-radius:8px;background:linear-gradient(135deg,#16a34a1a,#05966914);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;color:var(--accent)}.course-thumb img{width:100%;height:100%;object-fit:cover}.course-info{flex:1;min-width:0}.course-title{display:block;font-size:.9rem;font-weight:600;color:var(--text-primary)}.course-desc{display:block;font-size:.78rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:640px){.mygroups-page{padding:1.5rem 1rem}.mygroups-header{flex-direction:column;gap:.75rem}.mygroup-card-header{padding:1rem;flex-wrap:wrap;gap:.5rem}.mygroup-body-inner{padding:0 1rem 1rem}.mygroup-section-header{flex-direction:column;align-items:flex-start;gap:.5rem}.mygroup-search,.mygroup-search input{width:100%}}[data-theme=dark] .mygroups-empty,[data-theme=dark] .mygroup-card{background:#161616;border-color:#ffffff0f}[data-theme=dark] .mygroup-card.expanded{border-color:#16a34a40}[data-theme=dark] .mygroup-card-header:hover{background:#ffffff08}[data-theme=dark] .mygroup-body-inner{border-top-color:#ffffff0f}[data-theme=dark] .mygroup-search{border-color:#ffffff1a;background:#ffffff0a}[data-theme=dark] .mygroup-search:focus-within{background:#16a34a0f}[data-theme=dark] .mygroup-member:hover{background:#ffffff0a}[data-theme=dark] .mygroup-member.instructor-member{background:#f59e0b0f;border-color:#f59e0b1f}[data-theme=dark] .mygroup-member.instructor-member:hover{background:#f59e0b1a}[data-theme=dark] .mygroup-course:hover{background:#ffffff0a}[data-theme=dark] .mygroups-count-badge{background:#16a34a1f;border-color:#16a34a33}.member-profile-page{max-width:640px;margin:0 auto;padding:2.5rem 1.5rem}.member-profile-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}.member-profile-loading p{color:var(--text-secondary);font-size:.9rem}.member-profile-spinner{width:32px;height:32px;border:3px solid rgba(22,163,74,.15);border-top-color:var(--accent);border-radius:50%;animation:mpSpin .7s linear infinite}@keyframes mpSpin{to{transform:rotate(360deg)}}.member-profile-error{text-align:center;padding:4rem 2rem;border-radius:var(--radius-lg);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm)}.member-profile-error-icon{display:inline-flex;padding:1rem;border-radius:50%;background:#ef444414;color:#ef4444;margin-bottom:1rem}.member-profile-error h3{font-size:1.15rem;font-weight:600;color:var(--text-primary);margin:0 0 .5rem}.member-profile-error p{font-size:.9rem;color:var(--text-secondary);margin:0 0 1.5rem}.member-profile-back-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.25rem;border:1px solid rgba(0,0,0,.1);border-radius:var(--radius-sm);background:#fff;color:var(--text-primary);font-size:.85rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease}.member-profile-back-btn:hover{border-color:var(--accent);color:var(--accent);background:#16a34a0a}.member-profile-nav{margin-bottom:1.5rem}.member-profile-back{display:inline-flex;align-items:center;gap:.4rem;color:var(--text-secondary);font-size:.85rem;font-weight:500;text-decoration:none;transition:color .15s ease}.member-profile-back:hover{color:var(--accent)}.member-profile-hero{display:flex;align-items:center;gap:1.25rem;padding:1.75rem;border-radius:var(--radius-lg);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);margin-bottom:1.25rem}.member-profile-hero-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#059669);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;box-shadow:0 4px 16px #16a34a40}.member-profile-hero-avatar img{width:100%;height:100%;object-fit:cover}.member-profile-hero-info h1{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);margin:0 0 .15rem;display:flex;align-items:center;gap:.5rem}.own-profile-tag{display:inline-flex;padding:.12rem .5rem;border-radius:12px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.03em;background:#16a34a1a;color:var(--accent);border:1px solid rgba(22,163,74,.2)}.member-profile-username{font-size:.875rem;color:var(--text-secondary);margin:0 0 .5rem}.member-profile-role{display:inline-flex;padding:.2rem .65rem;border-radius:20px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.member-profile-details{display:flex;flex-direction:column;gap:1rem}.member-profile-card{border-radius:var(--radius-lg);background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:var(--shadow-sm);padding:1.5rem}.member-profile-card-header h3{display:flex;align-items:center;gap:.5rem;font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0 0 1.25rem}.member-profile-card-header h3 svg{color:var(--accent)}.member-profile-fields{display:flex;flex-direction:column;gap:.85rem}.member-profile-field{display:flex;align-items:center;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid rgba(0,0,0,.04)}.member-profile-field:last-child{border-bottom:none;padding-bottom:0}.field-label{display:flex;align-items:center;gap:.5rem;font-size:.85rem;font-weight:500;color:var(--text-secondary)}.field-label svg{color:var(--text-muted)}.field-value{font-size:.9rem;font-weight:500;color:var(--text-primary)}.member-profile-bio{font-size:.9rem;color:var(--text-secondary);line-height:1.6;margin:0}.member-profile-groups{display:flex;flex-wrap:wrap;gap:.5rem}.member-profile-group-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.35rem .75rem;border-radius:20px;background:#16a34a14;color:var(--accent);font-size:.8rem;font-weight:600;border:1px solid rgba(22,163,74,.15)}@media(max-width:640px){.member-profile-page{padding:1.5rem 1rem}.member-profile-hero{flex-direction:column;text-align:center}.member-profile-hero-info h1{justify-content:center;flex-wrap:wrap}.member-profile-field{flex-direction:column;align-items:flex-start;gap:.25rem}}[data-theme=dark] .member-profile-error{background:#161616;border-color:#ffffff0f}[data-theme=dark] .member-profile-back-btn{border-color:#ffffff1a;background:#ffffff0d}[data-theme=dark] .member-profile-back-btn:hover{background:#16a34a14}[data-theme=dark] .member-profile-hero,[data-theme=dark] .member-profile-card{background:#161616;border-color:#ffffff0f}[data-theme=dark] .member-profile-field{border-bottom-color:#ffffff0a}[data-theme=dark] .member-profile-group-chip{background:#16a34a1f;border-color:#16a34a33}.billing-container{max-width:800px;margin:0 auto;padding:2.5rem 1.5rem}.billing-header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .25rem;color:var(--text-primary)}.billing-subtitle{color:var(--text-secondary);font-size:.9rem;margin:0 0 2rem}.subscription-card{background:#fff;border-radius:16px;padding:1.5rem;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 3px #0000000a;margin-bottom:2rem}.subscription-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.subscription-card-header h3{font-size:1.1rem;font-weight:600;margin:0;color:var(--text-primary)}.subscription-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem}.sub-detail{display:flex;flex-direction:column;gap:.2rem}.sub-detail-label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.sub-detail-value{font-size:.95rem;font-weight:600;color:var(--text-primary)}.plans-section h3{font-size:1.1rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary)}.plans-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1rem;margin-bottom:2rem}.plan-card{background:#fff;border-radius:16px;padding:1.5rem;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 3px #0000000a;display:flex;flex-direction:column;transition:box-shadow .2s,transform .2s}.plan-card:hover{box-shadow:0 4px 16px #00000014}.plan-card-name{font-size:1.05rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.plan-card-desc{font-size:.82rem;color:var(--text-secondary);margin-bottom:1rem;flex:1}.plan-card-price{font-size:1.5rem;font-weight:700;color:#16a34a;margin-bottom:.25rem}.plan-card-duration{font-size:.78rem;color:var(--text-muted);margin-bottom:1rem}.plan-card-btn{width:100%;padding:.65rem 1rem;border:none;border-radius:10px;background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .2s}.plan-card-btn:hover{opacity:.9}.plan-card-btn:disabled{opacity:.5;cursor:not-allowed}.payment-history{margin-top:2rem}.payment-history h3{font-size:1.1rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary)}.payment-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:12px;overflow:hidden;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 3px #0000000a}.payment-table thead th{text-align:left;padding:.75rem 1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:#00000005;border-bottom:1px solid rgba(0,0,0,.06)}.payment-table tbody td{padding:.75rem 1rem;font-size:.85rem;color:var(--text-primary);border-bottom:1px solid rgba(0,0,0,.04)}.payment-table tbody tr:last-child td{border-bottom:none}.billing-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.billing-empty-icon{font-size:3rem;margin-bottom:1rem}.billing-empty p{font-size:.95rem;margin:0}.billing-loading{display:flex;justify-content:center;padding:3rem}.billing-spinner{width:32px;height:32px;border:3px solid rgba(0,0,0,.08);border-top-color:var(--accent);border-radius:50%;animation:billing-spin .7s linear infinite}@keyframes billing-spin{to{transform:rotate(360deg)}}.billing-success{background:#16a34a14;border:1px solid rgba(22,163,74,.2);border-radius:12px;padding:1rem 1.25rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;color:#16a34a;font-size:.9rem;font-weight:500}[data-theme=dark] .subscription-card,[data-theme=dark] .plan-card,[data-theme=dark] .payment-table{background:var(--bg-secondary);border-color:#ffffff0f}[data-theme=dark] .payment-table thead th{background:#ffffff08;border-bottom-color:#ffffff0f}[data-theme=dark] .payment-table tbody td{border-bottom-color:#ffffff0a}.payments-container{max-width:900px;margin:0 auto;padding:2.5rem 1.5rem}.payments-header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .25rem;color:var(--text-primary)}.payments-subtitle{color:var(--text-secondary);font-size:.9rem;margin:0 0 2rem}.payments-tabs{display:flex;gap:.25rem;padding:.3rem;background:var(--bg-secondary);border-radius:12px;margin-bottom:1.5rem;border:1px solid rgba(0,0,0,.04)}.payments-tab{position:relative;display:flex;align-items:center;gap:.45rem;padding:.6rem 1rem;border:none;background:none;color:var(--text-muted);font-size:.82rem;font-weight:500;font-family:inherit;cursor:pointer;border-radius:9px;transition:color .2s;white-space:nowrap}.payments-tab:hover{color:var(--text-primary)}.payments-tab.active{color:var(--text-primary);font-weight:600}.payments-tab-indicator{position:absolute;inset:0;background:#fff;border-radius:9px;z-index:0;box-shadow:0 1px 3px #00000014}.payments-tab>*{position:relative;z-index:1}.payments-tab-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;font-size:.7rem;font-weight:700;background:#16a34a1f;color:#16a34a}.section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1rem}.course-pay-card{background:#fff;border-radius:16px;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 3px #0000000a;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s}.course-pay-card:hover{box-shadow:0 6px 20px #00000014}.course-pay-logo{height:140px;background:linear-gradient(135deg,#f0fdf4,#e0f2fe);display:flex;align-items:center;justify-content:center;overflow:hidden}.course-pay-logo img{width:100%;height:100%;object-fit:cover}.course-pay-logo-placeholder{display:flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:14px;background:#16a34a1a;color:#16a34a}.course-pay-logo-placeholder.free{background:#3b82f61a;color:#3b82f6}.course-pay-card.free .course-pay-logo{background:linear-gradient(135deg,#eff6ff,#e0f2fe)}.course-pay-info{padding:1rem 1.25rem .5rem;flex:1}.course-pay-title{font-size:.95rem;font-weight:600;color:var(--text-primary);margin:0 0 .35rem}.course-pay-desc{font-size:.8rem;color:var(--text-secondary);margin:0;line-height:1.5}.course-pay-footer{padding:.75rem 1.25rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:.75rem}.course-pay-price{font-size:1.25rem;font-weight:700;color:#16a34a}.course-pay-price.free{color:#3b82f6;font-size:1rem}.course-free-badge{font-size:.75rem;color:var(--text-muted);font-style:italic}.course-pay-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border:none;border-radius:10px;background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;font-size:.82rem;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .2s}.course-pay-btn:hover{opacity:.9}.course-pay-btn:disabled{opacity:.5;cursor:not-allowed}.btn-loading-inline{display:inline-flex;align-items:center;gap:.4rem}.btn-spinner-small{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:payments-spin .6s linear infinite}.purchases-list{display:flex;flex-direction:column;gap:.5rem}.purchase-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.25rem;background:#fff;border-radius:12px;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 3px #0000000a}.purchase-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:#16a34a1a;color:#16a34a;flex-shrink:0}.purchase-info{flex:1;display:flex;flex-direction:column;gap:.15rem}.purchase-title{font-size:.9rem;font-weight:600;color:var(--text-primary)}.purchase-date{font-size:.78rem;color:var(--text-muted)}.purchase-amount{font-size:.95rem;font-weight:700;color:#16a34a}.payments-table-wrap{background:#fff;border-radius:12px;overflow:hidden;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 3px #0000000a}.payments-table{width:100%;border-collapse:separate;border-spacing:0}.payments-table thead th{text-align:left;padding:.75rem 1rem;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:#00000005;border-bottom:1px solid rgba(0,0,0,.06)}.payments-table tbody td{padding:.75rem 1rem;font-size:.85rem;color:var(--text-primary);border-bottom:1px solid rgba(0,0,0,.04)}.payments-table tbody tr:last-child td{border-bottom:none}.payments-empty{text-align:center;padding:3rem 1rem;color:var(--text-muted)}.payments-empty-icon{margin-bottom:1rem;opacity:.4}.payments-empty p{font-size:.95rem;margin:0}.payments-loading{display:flex;justify-content:center;padding:3rem}.payments-spinner{width:32px;height:32px;border:3px solid rgba(0,0,0,.08);border-top-color:var(--accent);border-radius:50%;animation:payments-spin .7s linear infinite}@keyframes payments-spin{to{transform:rotate(360deg)}}.payments-success{background:#16a34a14;border:1px solid rgba(22,163,74,.2);border-radius:12px;padding:1rem 1.25rem;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem;color:#16a34a;font-size:.9rem;font-weight:500}[data-theme=dark] .payments-tabs{border-color:#ffffff0f}[data-theme=dark] .payments-tab-indicator{background:var(--bg-tertiary);box-shadow:0 1px 3px #0000004d}[data-theme=dark] .course-pay-card,[data-theme=dark] .purchase-item,[data-theme=dark] .payments-table-wrap{background:var(--bg-secondary);border-color:#ffffff0f}[data-theme=dark] .course-pay-logo{background:linear-gradient(135deg,#16a34a14,#3b82f614)}[data-theme=dark] .course-pay-card.free .course-pay-logo{background:linear-gradient(135deg,#3b82f614,#6366f114)}[data-theme=dark] .payments-table thead th{background:#ffffff08;border-bottom-color:#ffffff0f}[data-theme=dark] .payments-table tbody td{border-bottom-color:#ffffff0a}@media(max-width:600px){.payments-container{padding:1.5rem 1rem}.courses-grid{grid-template-columns:1fr}.payments-tabs{overflow-x:auto}}.attendance-page{max-width:960px;margin:0 auto;padding:2.5rem 1.5rem}.attendance-header h1{font-size:1.75rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .35rem;color:var(--text-primary)}.attendance-header p{color:var(--text-secondary);margin:0 0 1.5rem}.attendance-tabs{display:flex;gap:.35rem;padding:.3rem;border-radius:12px;background:var(--bg-secondary);border:1px solid rgba(0,0,0,.06);margin-bottom:1rem}.attendance-tab{border:none;border-radius:9px;padding:.55rem .9rem;font:inherit;font-size:.85rem;color:var(--text-muted);background:transparent;cursor:pointer}.attendance-tab.active{color:var(--text-primary);background:#fff;box-shadow:0 1px 3px #00000014}.card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding:1rem}.attendance-form h3,.attendance-edit h3,.attendance-overview h3,.card h3{margin:0 0 .8rem;font-size:1rem}.attendance-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.8rem}.attendance-grid label{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;color:var(--text-secondary)}.attendance-grid select,.attendance-grid input,.attendance-grid textarea,.attendance-record-row select{border:1px solid rgba(0,0,0,.12);border-radius:8px;background:var(--bg-secondary);color:var(--text-primary);padding:.5rem .65rem;font:inherit;font-size:.84rem}.attendance-note{grid-column:1 / -1}.attendance-note textarea{min-height:70px;resize:vertical}.attendance-checkbox{display:flex;align-items:center;gap:.5rem;margin:.8rem 0;font-size:.84rem;color:var(--text-secondary)}.attendance-records{border-top:1px solid rgba(0,0,0,.08);margin-top:.8rem;padding-top:.8rem}.attendance-records h4{margin:0 0 .6rem;font-size:.88rem;color:var(--text-primary)}.attendance-record-row{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.attendance-record-row span{font-size:.85rem;color:var(--text-primary)}.attendance-button{margin-top:.8rem;border:none;border-radius:9px;padding:.6rem 1rem;font:inherit;font-size:.84rem;font-weight:600;background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff;cursor:pointer}.attendance-button:disabled{opacity:.6;cursor:not-allowed}.attendance-session-list{display:grid;gap:.8rem;margin-top:1rem}.attendance-session-top{display:flex;justify-content:space-between;gap:.75rem}.attendance-session-top h4{margin:0;font-size:.95rem}.attendance-session-top p{margin:.2rem 0 0;color:var(--text-secondary);font-size:.82rem}.attendance-session-actions{display:flex;gap:.5rem}.attendance-link-button{border:none;background:transparent;color:var(--accent);font:inherit;font-size:.82rem;cursor:pointer}.attendance-link-button.danger{color:var(--danger)}.attendance-note-text{margin:.6rem 0;color:var(--text-secondary);font-size:.85rem}.attendance-summary{display:flex;flex-wrap:wrap;gap:.45rem}.attendance-summary-item{display:inline-flex;align-items:center;gap:.4rem}.attendance-status{display:inline-flex;align-items:center;border:1px solid;border-radius:999px;font-size:.75rem;font-weight:600;padding:.18rem .55rem;text-transform:capitalize}.attendance-edit{margin-top:1rem}.attendance-edit-header{display:flex;justify-content:space-between;gap:.75rem;align-items:center}.attendance-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;margin-bottom:.9rem}.attendance-stats .card span{display:block;color:var(--text-muted);font-size:.78rem}.attendance-stats .card strong{font-size:1.35rem;color:var(--text-primary)}.attendance-overview{display:grid;gap:.9rem}.attendance-table{display:grid;gap:.45rem}.attendance-table-head,.attendance-table-row{display:grid;grid-template-columns:2fr 1fr 1fr;gap:.75rem;align-items:center}.attendance-table-head{color:var(--text-muted);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.attendance-table-row{border-top:1px solid rgba(0,0,0,.06);padding-top:.45rem;color:var(--text-primary);font-size:.84rem}.attendance-loading{padding:3rem 0;text-align:center;color:var(--text-secondary)}.attendance-filters{margin-bottom:1rem}.attendance-date-group{margin-bottom:1.5rem}.attendance-date-header{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0 0 .8rem;padding-bottom:.5rem;border-bottom:2px solid rgba(0,0,0,.08)}[data-theme=dark] .attendance-date-header{border-bottom-color:#ffffff14}@media(max-width:780px){.attendance-grid,.attendance-stats{grid-template-columns:1fr}}[data-theme=dark] .card,[data-theme=dark] .attendance-tab.active{background:#1e1e1e;border-color:#333}[data-theme=dark] .attendance-table-row,[data-theme=dark] .attendance-records{border-color:#ffffff14}.jf-page{max-width:1280px;margin:0 auto;padding:1.5rem 1.25rem 3rem}.jf-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:6rem 1rem;color:var(--text-muted)}.jf-spinner{width:36px;height:36px;border-radius:50%;border:3px solid rgba(22,163,74,.18);border-top-color:#16a34a;animation:jf-spin .8s linear infinite}@keyframes jf-spin{to{transform:rotate(360deg)}}.jf-topbar{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem;padding:.75rem 1.1rem;background:#fff;border:1px solid rgba(0,0,0,.07);border-radius:12px;box-shadow:0 1px 2px #00000008;margin-bottom:.85rem}.jf-topbar-left,.jf-topbar-right{display:flex;align-items:center;gap:.6rem}.jf-topbar-right{justify-content:flex-end}.jf-topbar-center{text-align:center;display:flex;flex-direction:column;gap:.15rem;min-width:0}.jf-page-title{margin:0;font-size:1.05rem;font-weight:800;letter-spacing:-.02em;color:var(--text-primary)}.jf-page-sub{font-size:.74rem;color:var(--text-muted);font-weight:500}.jf-brand{display:inline-flex;align-items:center;gap:.45rem;padding:.35rem .7rem;border-radius:8px;background:linear-gradient(135deg,#16a34a,#059669);color:#fff;font-weight:700;font-size:.85rem;letter-spacing:-.01em}.jf-divider{color:var(--text-muted);font-weight:300;opacity:.5}.jf-crumb{color:var(--text-secondary);font-size:.85rem;font-weight:500}[data-theme=dark] .jf-topbar{background:#1e1e1e;border-color:#2a2a2a}.jf-view-tabs{display:inline-flex;gap:2px;margin-bottom:1rem;background:#16a34a14;border-radius:10px;padding:4px}.jf-view-tab{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem 1rem;border:none;background:transparent;border-radius:7px;font-family:inherit;font-size:.82rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .18s ease}.jf-view-tab.active{background:#16a34a;color:#fff;box-shadow:0 1px 3px #16a34a59}.jf-view-tab.jf-view-tab-purple.active{background:#8b5cf6;box-shadow:0 1px 3px #8b5cf659}.jf-view-tab:not(.active):hover{color:var(--text-primary);background:#0000000a}[data-theme=dark] .jf-view-tabs{background:#16a34a1f}[data-theme=dark] .jf-view-tab:not(.active):hover{background:#ffffff0d}.jf-toolbar{display:grid;grid-template-columns:1fr auto;gap:.75rem;margin-bottom:.75rem}.jf-search{position:relative;display:flex;align-items:center;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:10px;padding:0 .85rem;height:40px;transition:border-color .18s ease,box-shadow .18s ease}.jf-search:focus-within{border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1f}.jf-search>svg{color:var(--text-muted);flex-shrink:0}.jf-search input{flex:1;border:none;background:transparent;outline:none;padding:0 .6rem;font-size:.88rem;font-family:inherit;color:var(--text-primary)}.jf-search-clear{border:none;background:transparent;color:var(--text-muted);cursor:pointer;padding:4px;display:flex;align-items:center;border-radius:4px}.jf-search-clear:hover{background:#0000000d;color:var(--text-primary)}.jf-filter-controls{display:flex;gap:.5rem}.jf-filter-select{padding:0 .85rem;height:40px;border:1px solid rgba(0,0,0,.08);border-radius:10px;background:#fff;font-family:inherit;font-size:.85rem;font-weight:500;color:var(--text-primary);cursor:pointer;min-width:140px;transition:border-color .18s ease}.jf-filter-select:hover{border-color:#0000002e}.jf-filter-select:focus{outline:none;border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1f}[data-theme=dark] .jf-search,[data-theme=dark] .jf-filter-select{background:#1e1e1e;border-color:#2a2a2a}.jf-chips{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:1rem}.jf-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:20px;border:1px solid rgba(0,0,0,.09);background:#fff;color:var(--text-secondary);font-size:.78rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s ease}.jf-chip:hover{border-color:#0000002e;color:var(--text-primary)}.jf-chip.active{font-weight:700}.jf-chip-dot{width:8px;height:8px;border-radius:50%}.jf-chip-count{background:#0000000f;padding:1px 7px;border-radius:10px;font-size:.7rem;font-weight:700;font-variant-numeric:tabular-nums;margin-left:.15rem}.jf-chip.active .jf-chip-count{background:#0000000f}[data-theme=dark] .jf-chip{background:#1e1e1e;border-color:#2a2a2a}[data-theme=dark] .jf-chip-count{background:#ffffff14}.jf-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:8px;border:1px solid transparent;font-family:inherit;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .15s ease;white-space:nowrap}.jf-btn:disabled{opacity:.55;cursor:not-allowed}.jf-btn-sm{padding:.42rem .85rem;font-size:.8rem}.jf-btn-primary{background:#16a34a;color:#fff;border-color:#16a34a}.jf-btn-primary:hover:not(:disabled){background:#15803d;border-color:#15803d;box-shadow:0 2px 8px #16a34a4d}.jf-btn-ghost{background:#fff;color:var(--text-secondary);border-color:#0000001a}.jf-btn-ghost:hover:not(:disabled){background:#00000005;color:var(--text-primary);border-color:#0000002e}.jf-btn-danger{background:#ef4444;color:#fff;border-color:#ef4444}.jf-btn-danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626}[data-theme=dark] .jf-btn-ghost{background:#1e1e1e;border-color:#2a2a2a}[data-theme=dark] .jf-btn-ghost:hover:not(:disabled){background:#232323;border-color:#3a3a3a}.jf-icon-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid rgba(0,0,0,.08);background:#fff;border-radius:8px;cursor:pointer;color:var(--text-secondary);transition:all .15s ease}.jf-icon-btn:hover{background:#0000000a;color:var(--text-primary)}.jf-icon-btn-sm{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid rgba(0,0,0,.08);background:#fff;border-radius:6px;cursor:pointer;color:var(--text-secondary);transition:all .15s ease}.jf-icon-btn-sm:hover{background:#16a34a14;color:#16a34a;border-color:#16a34a4d}.jf-icon-btn-sm.jf-icon-btn-danger:hover{background:#ef444414;color:#ef4444;border-color:#ef44444d}[data-theme=dark] .jf-icon-btn,[data-theme=dark] .jf-icon-btn-sm{background:#1e1e1e;border-color:#2a2a2a}.jf-bulk-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.65rem 1rem;background:linear-gradient(135deg,#16a34a,#059669);color:#fff;border-radius:10px;margin-bottom:.75rem;font-size:.85rem;box-shadow:0 4px 14px #16a34a40}.jf-bulk-bar strong{font-weight:800}.jf-bulk-actions{display:flex;gap:.5rem}.jf-bulk-bar .jf-btn-ghost{background:#ffffff26;color:#fff;border-color:#ffffff4d}.jf-bulk-bar .jf-btn-ghost:hover{background:#ffffff40}.jf-table-wrap{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:12px;overflow-x:auto;box-shadow:0 1px 3px #00000008}.jf-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.86rem;min-width:920px}.jf-table thead{background:#f7f8f9}.jf-table thead th{padding:.75rem .95rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-secondary);border-bottom:1px solid rgba(0,0,0,.07);white-space:nowrap;text-align:left;-webkit-user-select:none;user-select:none}.jf-table thead th.sortable{cursor:pointer;transition:background .15s ease,color .15s ease}.jf-table thead th.sortable:hover{color:var(--text-primary);background:#00000005}.jf-th-inner{display:inline-flex;align-items:center;gap:.4rem}.jf-th-inner svg{color:var(--text-muted);flex-shrink:0}.jf-arrow{font-size:.55rem;color:#16a34a;margin-left:2px}.jf-th-check{width:38px;padding:0 .5rem}.jf-th-num{width:44px;text-align:center!important;padding:.75rem .5rem;color:var(--text-muted);font-size:.7rem}.jf-th-actions{width:80px}.jf-table tbody td{padding:.7rem .95rem;border-bottom:1px solid rgba(0,0,0,.04);color:var(--text-secondary);vertical-align:middle}.jf-table tbody tr{transition:background .12s ease}.jf-table tbody tr:last-child td{border-bottom:none}.jf-table tbody tr:hover td{background:#16a34a06}.jf-table tbody tr.selected td{background:#16a34a0f}.jf-td-check{text-align:center;padding:.7rem .5rem!important;width:38px}.jf-td-num{width:44px;text-align:center!important;color:var(--text-muted);font-size:.78rem;font-variant-numeric:tabular-nums;background:#00000003}.jf-td-actions{text-align:right;white-space:nowrap}.jf-row-actions{display:inline-flex;gap:.3rem;opacity:0;transition:opacity .15s ease}.jf-table tbody tr:hover .jf-row-actions{opacity:1}[data-theme=dark] .jf-table-wrap{background:#1e1e1e;border-color:#2a2a2a}[data-theme=dark] .jf-table thead{background:#232323}[data-theme=dark] .jf-table thead th{border-bottom-color:#ffffff0f}[data-theme=dark] .jf-table thead th.sortable:hover{background:#ffffff08}[data-theme=dark] .jf-table tbody td{border-bottom-color:#ffffff0a}[data-theme=dark] .jf-table tbody tr:hover td{background:#16a34a0f}[data-theme=dark] .jf-td-num{background:#ffffff05}.jf-cell-date{color:var(--text-primary);font-weight:500;font-size:.84rem;font-variant-numeric:tabular-nums}.jf-cell-student{display:flex;align-items:center;gap:.65rem}.jf-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#16a34a,#059669);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0;box-shadow:0 1px 3px #16a34a4d}.jf-avatar-sm{width:28px;height:28px;font-size:.75rem}.jf-primary{color:var(--text-primary);font-weight:600;font-size:.86rem;line-height:1.3}.jf-secondary{color:var(--text-muted);font-size:.76rem;line-height:1.3}.jf-note-cell{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;max-width:220px;font-size:.83rem;color:var(--text-secondary)}.jf-pill{display:inline-flex;align-items:center;padding:.35rem .8rem;border-radius:6px;font-size:.76rem;font-weight:700;letter-spacing:.02em;border:none;font-family:inherit}.jf-pill-editable{cursor:pointer;transition:filter .15s ease}.jf-pill-editable:hover{filter:brightness(.95)}.jf-pill-wrap{position:relative;display:inline-block}.jf-pill-backdrop{position:fixed;inset:0;z-index:50}.jf-pill-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:51;background:#fff;border:1px solid rgba(0,0,0,.1);border-radius:9px;box-shadow:0 10px 30px #00000026;padding:4px;min-width:140px;display:flex;flex-direction:column;gap:1px}.jf-pill-option{display:flex;align-items:center;gap:.5rem;padding:.45rem .75rem;border:none;background:transparent;font-family:inherit;font-size:.83rem;color:var(--text-primary);cursor:pointer;border-radius:6px;text-align:left;width:100%;font-weight:500;transition:background .12s ease}.jf-pill-option:hover{background:color-mix(in srgb,var(--opt-color) 12%,transparent)}.jf-pill-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}[data-theme=dark] .jf-pill-menu{background:#232323;border-color:#ffffff1a}.jf-month-pill{display:inline-block;padding:.3rem .7rem;border-radius:6px;background:#f59e0b26;color:#d97706;font-size:.76rem;font-weight:700}[data-theme=dark] .jf-month-pill{background:#f59e0b2e;color:#fbbf24}.jf-pagination{display:flex;justify-content:space-between;align-items:center;padding:1rem .5rem;flex-wrap:wrap;gap:.75rem}.jf-page-info{font-size:.8rem;color:var(--text-muted)}.jf-page-controls{display:flex;align-items:center;gap:.4rem}.jf-page-current{font-size:.82rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;min-width:60px;text-align:center}.jf-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 1rem;text-align:center;background:#fff;border:1px dashed rgba(0,0,0,.12);border-radius:12px;gap:.5rem}.jf-empty-state svg{color:var(--text-muted);opacity:.5;margin-bottom:.5rem}.jf-empty-state h3{margin:0;font-size:1rem;font-weight:700;color:var(--text-primary)}.jf-empty-state p{margin:0 0 1rem;color:var(--text-muted);font-size:.88rem}.jf-empty-inline{padding:1.5rem 1rem;text-align:center;color:var(--text-muted);font-size:.85rem;border:1px dashed rgba(0,0,0,.1);border-radius:10px}[data-theme=dark] .jf-empty-state,[data-theme=dark] .jf-empty-inline{background:#1e1e1e;border-color:#ffffff14}.jf-charts{display:flex;flex-direction:column;gap:1rem}.jf-charts-summary{display:grid;grid-template-columns:repeat(4,1fr);background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:12px;overflow:hidden}.jf-stat{display:flex;flex-direction:column;gap:.25rem;padding:1rem 1.1rem;border-right:1px solid rgba(0,0,0,.05)}.jf-stat:last-child{border-right:none}.jf-stat-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.jf-stat-value{font-size:1.5rem;font-weight:800;letter-spacing:-.03em;color:var(--text-primary)}.jf-card{background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:12px;padding:1.1rem 1.2rem;box-shadow:0 1px 3px #00000008}.jf-card-title{margin:0 0 .85rem;font-size:.92rem;font-weight:700;color:var(--text-primary)}.jf-charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}[data-theme=dark] .jf-charts-summary,[data-theme=dark] .jf-card{background:#1e1e1e;border-color:#2a2a2a}[data-theme=dark] .jf-stat{border-right-color:#ffffff0d}.jf-drawer-backdrop{position:fixed;inset:0;background:#0f172a80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:200}.jf-drawer{position:fixed;top:0;right:0;bottom:0;width:min(640px,100%);background:#fff;z-index:201;display:flex;flex-direction:column;box-shadow:-10px 0 30px #00000026}.jf-drawer-head{display:flex;justify-content:space-between;align-items:flex-start;padding:1.1rem 1.4rem;border-bottom:1px solid rgba(0,0,0,.06)}.jf-drawer-eyebrow{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#16a34a}.jf-drawer-title{margin:.1rem 0 0;font-size:1.25rem;font-weight:800;letter-spacing:-.02em;color:var(--text-primary)}.jf-drawer-body{flex:1;overflow-y:auto;padding:1.2rem 1.4rem;display:flex;flex-direction:column;gap:1rem}.jf-drawer-foot{display:flex;justify-content:flex-end;gap:.5rem;padding:1rem 1.4rem;border-top:1px solid rgba(0,0,0,.06);background:#fafafa}[data-theme=dark] .jf-drawer{background:#161616}[data-theme=dark] .jf-drawer-head,[data-theme=dark] .jf-drawer-foot{border-color:#ffffff0f}[data-theme=dark] .jf-drawer-foot{background:#1a1a1a}.jf-field-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.75rem}.jf-field{display:flex;flex-direction:column;gap:.35rem;min-width:0}.jf-field-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.jf-required{color:#ef4444}.jf-input{padding:.55rem .75rem;border:1px solid rgba(0,0,0,.1);border-radius:8px;background:#fff;font-family:inherit;font-size:.88rem;color:var(--text-primary);transition:border-color .15s ease,box-shadow .15s ease;width:100%}.jf-input:focus{outline:none;border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1f}.jf-input:disabled{background:#00000008;color:var(--text-muted);cursor:not-allowed}.jf-textarea{resize:vertical;min-height:60px;font-family:inherit}.jf-checkbox{display:inline-flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none}.jf-checkbox input{width:16px;height:16px;accent-color:#16a34a;cursor:pointer}[data-theme=dark] .jf-input{background:#232323;border-color:#ffffff1a;color:var(--text-primary)}[data-theme=dark] .jf-input:disabled{background:#ffffff0a}.jf-alert{display:flex;align-items:flex-start;gap:.6rem;padding:.7rem .9rem;border-radius:8px;font-size:.83rem;line-height:1.4}.jf-alert-warn{background:#f59e0b1a;color:#92400e;border:1px solid rgba(245,158,11,.25)}.jf-alert-error{background:#ef444414;color:#991b1b;border:1px solid rgba(239,68,68,.25)}[data-theme=dark] .jf-alert-warn{background:#f59e0b1f;color:#fbbf24;border-color:#f59e0b4d}[data-theme=dark] .jf-alert-error{background:#ef44441a;color:#fca5a5;border-color:#ef44444d}.jf-students{border:1px solid rgba(0,0,0,.08);border-radius:10px;overflow:hidden}.jf-students-head{display:flex;justify-content:space-between;align-items:center;padding:.7rem .9rem;background:#f7f8f9;font-size:.78rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;flex-wrap:wrap;gap:.5rem}.jf-quick-set{display:flex;flex-wrap:wrap;gap:.3rem}.jf-quick-btn{padding:.25rem .55rem;border:1px solid;border-radius:6px;background:transparent;font-family:inherit;font-size:.7rem;font-weight:700;cursor:pointer;transition:all .15s ease;text-transform:uppercase;letter-spacing:.04em}.jf-quick-btn:hover{background:currentColor;color:#fff!important}.jf-student-list{max-height:360px;overflow-y:auto}.jf-student-row{display:flex;justify-content:space-between;align-items:center;padding:.7rem .9rem;border-top:1px solid rgba(0,0,0,.05);gap:1rem}.jf-student-info{display:flex;align-items:center;gap:.7rem;min-width:0}.jf-student-name{font-size:.88rem;font-weight:600;color:var(--text-primary);line-height:1.3}.jf-student-meta{font-size:.73rem;color:var(--text-muted)}.jf-status-picker{display:flex;flex-wrap:wrap;gap:.3rem;flex-shrink:0}.jf-status-chip{padding:.3rem .6rem;border:1px solid;border-radius:6px;background:transparent;font-family:inherit;font-size:.72rem;font-weight:700;cursor:pointer;transition:all .15s ease;letter-spacing:.02em}.jf-status-chip:hover{background:currentColor;color:#fff!important}.jf-status-chip.active{box-shadow:0 1px 4px #00000026}[data-theme=dark] .jf-students{border-color:#ffffff14}[data-theme=dark] .jf-students-head{background:#232323}[data-theme=dark] .jf-student-row{border-top-color:#ffffff0d}.jf-modal-backdrop{position:fixed;inset:0;background:#0f172a80;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:300}.jf-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:14px;padding:1.5rem 1.5rem 1.25rem;z-index:301;box-shadow:0 20px 50px #00000040;min-width:320px;max-width:460px;width:calc(100% - 2rem)}.jf-modal-title{margin:0 0 .4rem;font-size:1.05rem;font-weight:800;letter-spacing:-.01em;color:var(--text-primary)}.jf-modal-msg{margin:0 0 1.25rem;font-size:.88rem;color:var(--text-secondary);line-height:1.5}.jf-modal-actions{display:flex;justify-content:flex-end;gap:.5rem}[data-theme=dark] .jf-modal{background:#1e1e1e}.jf-summary-bar{display:flex;flex-direction:column;gap:.5rem}.jf-summary-track{display:flex;height:8px;border-radius:4px;overflow:hidden;background:#0000000d}.jf-summary-seg{transition:filter .15s ease}.jf-summary-seg:hover{filter:brightness(1.1)}.jf-summary-counts{display:flex;flex-wrap:wrap;gap:.85rem;font-size:.78rem}.jf-summary-count{display:inline-flex;align-items:center;gap:.3rem}@media(max-width:900px){.jf-topbar{grid-template-columns:1fr;gap:.6rem;text-align:center}.jf-topbar-left,.jf-topbar-right{justify-content:center}.jf-toolbar,.jf-charts-grid{grid-template-columns:1fr}.jf-charts-summary,.jf-field-row{grid-template-columns:1fr 1fr}}@media(max-width:600px){.jf-page{padding:1rem .75rem 2rem}.jf-table{min-width:720px;font-size:.82rem}.jf-charts-summary{grid-template-columns:1fr 1fr}.jf-stat{border-right:none;border-bottom:1px solid rgba(0,0,0,.05);padding:.85rem}[data-theme=dark] .jf-stat{border-bottom-color:#ffffff0d}.jf-field-row{grid-template-columns:1fr}.jf-pagination{flex-direction:column;align-items:stretch}.jf-page-controls{justify-content:center}.jf-row-actions{opacity:1}}.msg-page{display:grid;grid-template-columns:360px 1fr;height:calc(100vh - 1rem);max-height:calc(100vh - 1rem);background:var(--bg-primary, #f3f4f6);overflow:hidden}.msg-loading{grid-column:1 / -1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.85rem;color:var(--text-muted, #9ca3af)}.msg-spinner{width:30px;height:30px;border-radius:50%;border:3px solid rgba(22,163,74,.18);border-top-color:#16a34a;animation:msg-spin .8s linear infinite}@keyframes msg-spin{to{transform:rotate(360deg)}}.msg-sidebar{display:flex;flex-direction:column;background:#fff;border-right:1px solid rgba(0,0,0,.06);overflow:hidden;min-width:0}.msg-sidebar-head{padding:1rem 1rem .65rem;border-bottom:1px solid rgba(0,0,0,.05);flex-shrink:0;background:#fff}.msg-sidebar-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:.85rem}.msg-sidebar-title{margin:0;font-size:1.45rem;font-weight:800;letter-spacing:-.025em;color:var(--text-primary, #1f2937)}.msg-total-unread{background:linear-gradient(135deg,#16a34a,#059669);color:#fff;font-size:.72rem;font-weight:800;padding:.18rem .55rem;border-radius:12px;min-width:24px;text-align:center;box-shadow:0 2px 6px #16a34a59}.msg-search-bar{display:flex;align-items:center;gap:.5rem;background:#0000000a;border:1px solid transparent;border-radius:18px;padding:.45rem .85rem;transition:background .15s ease,border-color .15s ease;margin-bottom:.7rem}.msg-search-bar:focus-within{background:#fff;border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1f}.msg-search-bar>svg{color:var(--text-muted, #9ca3af);flex-shrink:0}.msg-search-bar input{flex:1;border:none;background:transparent;outline:none;font-size:.86rem;font-family:inherit;color:var(--text-primary, #1f2937)}.msg-search-bar input::placeholder{color:var(--text-muted, #9ca3af)}.msg-search-clear{width:18px;height:18px;border:none;background:#0000002e;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0}.msg-filter-tabs{display:flex;gap:4px;padding:3px;background:#0000000a;border-radius:9px}.msg-filter-tab{flex:1;display:inline-flex;align-items:center;justify-content:center;gap:.3rem;padding:.4rem .5rem;border:none;background:transparent;border-radius:7px;font-family:inherit;font-size:.78rem;font-weight:600;color:var(--text-secondary, #6b7280);cursor:pointer;transition:all .15s ease}.msg-filter-tab:hover:not(.active){color:var(--text-primary, #1f2937)}.msg-filter-tab.active{background:#fff;color:var(--text-primary, #1f2937);font-weight:700;box-shadow:0 1px 3px #00000012}.msg-filter-count{background:#ef4444;color:#fff;font-size:.6rem;font-weight:800;padding:1px 5px;border-radius:8px;min-width:14px;text-align:center}.msg-sidebar-list{flex:1;overflow-y:auto;padding:.4rem .5rem 1rem}.msg-sidebar-list::-webkit-scrollbar{width:6px}.msg-sidebar-list::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}.msg-list-heading{padding:.7rem .6rem .4rem;font-size:.66rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted, #9ca3af)}.msg-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:3rem 1rem;color:var(--text-muted, #9ca3af);text-align:center}.msg-list-empty svg{opacity:.4}.msg-list-empty p{margin:0;font-size:.85rem}.conv-row{display:flex;align-items:center;gap:.7rem;padding:.7rem;border:none;background:transparent;border-radius:10px;font-family:inherit;cursor:pointer;width:100%;text-align:left;transition:background .12s ease}.conv-row:hover{background:#00000009}.conv-row.active{background:linear-gradient(135deg,#16a34a1f,#0891b20f)}.conv-row-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.conv-row-top{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.conv-row-name{font-size:.92rem;font-weight:600;color:var(--text-primary, #1f2937);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.conv-row.active .conv-row-name{color:#16a34a;font-weight:700}.conv-row-time{font-size:.7rem;color:var(--text-muted, #9ca3af);flex-shrink:0;font-variant-numeric:tabular-nums}.conv-row-bottom{display:flex;justify-content:space-between;align-items:center;gap:.4rem}.conv-row-preview{font-size:.8rem;color:var(--text-muted, #9ca3af);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.conv-unread{display:inline-block;background:#16a34a;color:#fff;font-size:.66rem;font-weight:800;min-width:20px;padding:1px 6px;border-radius:10px;text-align:center;flex-shrink:0}.msg-avatar{border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:700;flex-shrink:0;-webkit-user-select:none;user-select:none;letter-spacing:-.01em;position:relative}.msg-avatar-group{border-radius:14px}.msg-chat{display:flex;flex-direction:column;background:#fbfafa;background-image:radial-gradient(circle at 20% 35%,rgba(22,163,74,.04) 0px,transparent 360px),radial-gradient(circle at 80% 65%,rgba(8,145,178,.04) 0px,transparent 420px);overflow:hidden;min-width:0}.msg-empty-chat{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;text-align:center;color:var(--text-muted, #9ca3af);padding:2rem}.msg-empty-icon{width:100px;height:100px;border-radius:50%;background:linear-gradient(135deg,#16a34a1a,#0891b214);display:flex;align-items:center;justify-content:center;color:#16a34a;margin-bottom:.75rem}.msg-empty-chat h2{margin:0;font-size:1.1rem;font-weight:700;color:var(--text-primary, #1f2937)}.msg-empty-chat p{margin:0;font-size:.88rem}.msg-chat-head{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.1rem;background:#fff;border-bottom:1px solid rgba(0,0,0,.06);flex-shrink:0;z-index:5;box-shadow:0 1px 3px #00000005}.msg-back-btn{display:none;width:30px;height:30px;border:none;background:transparent;border-radius:50%;color:var(--text-secondary, #4b5563);cursor:pointer}.msg-back-btn:hover{background:#0000000d}.msg-chat-info{flex:1;min-width:0}.msg-chat-name{font-size:1rem;font-weight:700;letter-spacing:-.01em;color:var(--text-primary, #1f2937);line-height:1.2}.msg-chat-status{display:inline-flex;align-items:center;gap:.35rem;font-size:.78rem;color:var(--text-muted, #9ca3af);margin-top:1px}.msg-online-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 2px #22c55e40}.msg-conn{display:inline-flex;align-items:center;gap:.35rem;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.25rem .6rem;border-radius:12px;background:#22c55e1a;color:#16a34a;flex-shrink:0}.msg-conn.disconnected,.msg-conn.error{background:#ef444414;color:#ef4444}.msg-conn-dot{width:6px;height:6px;border-radius:50%;background:currentColor;animation:msg-pulse 1.6s ease-out infinite}@keyframes msg-pulse{0%,to{opacity:1}50%{opacity:.45}}.msg-thread{flex:1;overflow-y:auto;padding:1rem clamp(.85rem,4vw,2.5rem);display:flex;flex-direction:column;gap:2px}.msg-thread::-webkit-scrollbar{width:6px}.msg-thread::-webkit-scrollbar-thumb{background:#00000026;border-radius:3px}.msg-thread-loading,.msg-thread-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;padding:2rem;color:var(--text-muted, #9ca3af)}.msg-thread-empty h3{margin:.5rem 0 0;font-size:1rem;font-weight:700;color:var(--text-primary, #1f2937)}.msg-thread-empty p{margin:0;font-size:.86rem}.msg-day-sep{display:flex;align-items:center;justify-content:center;margin:1.1rem 0 .6rem}.msg-day-sep span{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted, #9ca3af);background:#fff;padding:.3rem .85rem;border-radius:14px;box-shadow:0 1px 3px #0000000d;border:1px solid rgba(0,0,0,.04)}.msg-row{display:flex;align-items:flex-end;gap:.5rem;margin:1px 0}.msg-row-mine{flex-direction:row-reverse}.msg-row-avatar{width:28px;display:flex;align-items:flex-end;flex-shrink:0}.msg-bubble{max-width:min(560px,70%);padding:.55rem .85rem .4rem;border-radius:16px;background:#fff;border:1px solid rgba(0,0,0,.05);box-shadow:0 1px 1.5px #0000000a;position:relative;word-wrap:break-word}.msg-bubble-mine{background:linear-gradient(135deg,#16a34a,#059669);color:#fff;border-color:transparent;box-shadow:0 1px 4px #16a34a52}.msg-bubble-last:not(.msg-bubble-mine){border-bottom-left-radius:4px}.msg-bubble-last.msg-bubble-mine{border-bottom-right-radius:4px}.msg-bubble-sender{font-size:.72rem;font-weight:700;margin-bottom:.15rem;color:#16a34a;letter-spacing:-.01em}.msg-bubble-mine .msg-bubble-sender{color:#ffffffd9}.msg-bubble-body{font-size:.92rem;line-height:1.4;white-space:pre-wrap;color:var(--text-primary, #1f2937)}.msg-bubble-mine .msg-bubble-body{color:#fff}.msg-bubble-foot{display:flex;align-items:center;justify-content:flex-end;gap:.3rem;margin-top:2px;margin-left:.5rem;font-size:.66rem;color:var(--text-muted, #9ca3af)}.msg-bubble-mine .msg-bubble-foot{color:#ffffffc7}.msg-bubble-time{font-variant-numeric:tabular-nums}.msg-tick{display:inline-flex;align-items:center;color:#fff9}.msg-tick.read{color:#38bdf8}.msg-typing{display:inline-flex;align-items:center;gap:4px;padding:.7rem .95rem;background:#fff;border-radius:16px;border:1px solid rgba(0,0,0,.05)}.msg-typing span{width:7px;height:7px;border-radius:50%;background:#9ca3af;animation:msg-bounce 1.2s infinite ease-in-out}.msg-typing span:nth-child(2){animation-delay:.18s}.msg-typing span:nth-child(3){animation-delay:.36s}@keyframes msg-bounce{0%,60%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(-5px);opacity:1}}.msg-composer{display:flex;align-items:center;gap:.5rem;padding:.7rem 1rem .85rem;background:#fff;border-top:1px solid rgba(0,0,0,.06);flex-shrink:0}.msg-compose-icon{width:36px;height:36px;border:none;background:transparent;color:var(--text-muted, #9ca3af);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;flex-shrink:0}.msg-compose-icon:hover{color:#16a34a;background:#16a34a14}.msg-composer input{flex:1;border:1px solid transparent;background:#0000000a;border-radius:22px;padding:.7rem 1.1rem;font-family:inherit;font-size:.92rem;color:var(--text-primary, #1f2937);outline:none;transition:all .15s ease}.msg-composer input:focus{background:#fff;border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1f}.msg-composer input::placeholder{color:var(--text-muted, #9ca3af)}.msg-send{width:40px;height:40px;border:none;border-radius:50%;background:linear-gradient(135deg,#16a34a,#059669);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s ease;box-shadow:0 2px 8px #16a34a4d}.msg-send:hover:not(:disabled){transform:scale(1.06);box-shadow:0 4px 14px #16a34a73}.msg-send:active:not(:disabled){transform:scale(.95)}.msg-send:disabled{background:#d1d5db;cursor:not-allowed;box-shadow:none}[data-theme=dark] .msg-page{background:#0f0f0f}[data-theme=dark] .msg-sidebar,[data-theme=dark] .msg-sidebar-head,[data-theme=dark] .msg-chat-head,[data-theme=dark] .msg-composer{background:#1a1a1a;border-color:#ffffff0f}[data-theme=dark] .msg-search-bar{background:#ffffff0d}[data-theme=dark] .msg-search-bar:focus-within{background:#232323;border-color:#16a34a}[data-theme=dark] .msg-filter-tabs{background:#ffffff0a}[data-theme=dark] .msg-filter-tab.active{background:#2a2a2a}[data-theme=dark] .conv-row:hover{background:#ffffff0a}[data-theme=dark] .conv-row.active{background:linear-gradient(135deg,#16a34a2e,#0891b21a)}[data-theme=dark] .msg-chat{background:#0a0a0a}[data-theme=dark] .msg-bubble{background:#232323;border-color:#ffffff0f}[data-theme=dark] .msg-bubble-body{color:#e5e7eb}[data-theme=dark] .msg-day-sep span{background:#232323;color:#9ca3af;border-color:#ffffff0f}[data-theme=dark] .msg-composer input{background:#ffffff0d;color:#e5e7eb}[data-theme=dark] .msg-composer input:focus{background:#232323}[data-theme=dark] .msg-typing{background:#232323;border-color:#ffffff0f}@media(max-width:820px){.msg-page{grid-template-columns:1fr}.msg-sidebar{position:absolute;inset:0;z-index:10}.msg-page-chat-active .msg-sidebar{display:none}.msg-back-btn{display:inline-flex;align-items:center;justify-content:center}.msg-bubble{max-width:78%}}.tutor-page{display:flex;flex-direction:column;height:calc(100vh - 1rem);max-height:calc(100vh - 1rem);margin:0;background:var(--bg-primary, #f7f8fa);overflow:hidden}.tutor-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem 1.4rem;background:#fff;border-bottom:1px solid rgba(0,0,0,.06);flex-shrink:0}.tutor-header-left{display:flex;align-items:center;gap:.85rem}.tutor-sidebar-toggle{width:34px;height:34px;border-radius:8px;border:1px solid rgba(0,0,0,.08);background:#fff;color:var(--text-secondary, #6b7280);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s ease,color .15s ease}.tutor-sidebar-toggle:hover{background:#0000000a;color:var(--text-primary, #1f2937)}.tutor-brand{display:flex;align-items:center;gap:.7rem}.tutor-brand-icon{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,#16a34a,#059669,#0891b2);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #16a34a4d}.tutor-title{margin:0;font-size:1.1rem;font-weight:800;letter-spacing:-.02em;color:var(--text-primary, #1f2937);line-height:1.1}.tutor-subtitle{display:flex;align-items:center;gap:.35rem;font-size:.76rem;color:var(--text-muted, #9ca3af);margin-top:2px}.tutor-online-dot{width:7px;height:7px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 2px #22c55e4d;animation:tutor-pulse 2s ease-out infinite}@keyframes tutor-pulse{0%,to{opacity:1}50%{opacity:.5}}.tutor-new-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1rem;border:1px solid rgba(22,163,74,.3);background:#16a34a0f;color:#16a34a;border-radius:8px;font-family:inherit;font-size:.83rem;font-weight:600;cursor:pointer;transition:all .15s ease}.tutor-new-btn:hover:not(:disabled){background:#16a34a1f;border-color:#16a34a80}.tutor-new-btn:disabled{opacity:.4;cursor:not-allowed}.tutor-body{display:flex;flex:1;min-height:0;overflow:hidden}.tutor-sidebar{flex-shrink:0;background:#fff;border-right:1px solid rgba(0,0,0,.06);overflow:hidden}.tutor-sidebar-inner{width:280px;height:100%;overflow-y:auto;padding:1.1rem 1rem;display:flex;flex-direction:column;gap:1.25rem}.tutor-sidebar-section{display:flex;flex-direction:column;gap:.85rem}.tutor-sidebar-heading{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted, #9ca3af);margin:0 0 .25rem;padding:0 .25rem}.tutor-cat{display:flex;flex-direction:column;gap:.3rem}.tutor-cat-head{display:flex;align-items:center;gap:.4rem;padding:.25rem;font-size:.78rem;font-weight:700}.tutor-prompt{display:block;text-align:left;width:100%;padding:.55rem .75rem;background:#fafafa;border:1px solid rgba(0,0,0,.05);border-radius:8px;font-family:inherit;font-size:.8rem;color:var(--text-secondary, #4b5563);cursor:pointer;transition:all .15s ease;line-height:1.35}.tutor-prompt:hover:not(:disabled){background:#fff;border-color:#16a34a;color:var(--text-primary, #1f2937);transform:translate(2px);box-shadow:0 2px 8px #16a34a1f}.tutor-prompt:disabled{opacity:.5;cursor:not-allowed}.tutor-sidebar-tip{margin-top:auto;padding:.85rem .95rem;background:linear-gradient(135deg,#16a34a14,#0891b20f);border:1px solid rgba(22,163,74,.18);border-radius:10px;font-size:.78rem;line-height:1.5;color:var(--text-secondary, #4b5563)}.tutor-sidebar-tip strong{color:var(--text-primary, #1f2937)}.tutor-main{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.tutor-msgs{flex:1;overflow-y:auto;padding:1.5rem clamp(1rem,6vw,4rem);display:flex;flex-direction:column;gap:1.25rem}.tutor-msgs::-webkit-scrollbar{width:8px}.tutor-msgs::-webkit-scrollbar-thumb{background:#00000026;border-radius:4px}.tutor-msg{display:flex;gap:.85rem;max-width:100%;align-items:flex-start}.tutor-msg-avatar{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,#16a34a,#0891b2);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-weight:700;font-size:.85rem;box-shadow:0 2px 6px #16a34a40}.tutor-msg-avatar-user{background:linear-gradient(135deg,#6366f1,#8b5cf6);box-shadow:0 2px 6px #6366f140}.tutor-msg-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.3rem}.tutor-msg-name{font-size:.78rem;font-weight:700;color:var(--text-primary, #1f2937)}.tutor-msg-bubble{font-size:.92rem;line-height:1.6;color:var(--text-primary, #1f2937);white-space:pre-wrap;word-wrap:break-word}.tutor-msg-bubble strong{font-weight:700}.tutor-msg-bubble em{font-style:italic}.tutor-msg-bubble a{color:#16a34a;text-decoration:underline;text-underline-offset:2px}.tutor-inline-code,.t-inline-code{background:#0000000d;padding:2px 6px;border-radius:4px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace;font-size:.85em;color:#c026d3}.t-code{position:relative;background:#1f2937;color:#e5e7eb;padding:1rem 1.1rem;border-radius:10px;font-family:ui-monospace,SFMono-Regular,SF Mono,Menlo,Consolas,monospace;font-size:.84rem;line-height:1.55;margin:.6rem 0;overflow-x:auto;white-space:pre;border:1px solid rgba(255,255,255,.04);box-shadow:0 4px 12px #0000002e}.t-code-lang{position:absolute;top:.4rem;right:.7rem;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#9ca3af;font-weight:600}.tutor-msg-error .tutor-msg-bubble{background:#ef44440f;border-left:3px solid #ef4444;padding:.75rem .95rem;border-radius:8px;color:#b91c1c}.tutor-typing{display:inline-flex;gap:5px;padding:.7rem 0}.tutor-typing span{width:8px;height:8px;border-radius:50%;background:#9ca3af;animation:tutor-bounce 1.2s infinite ease-in-out}.tutor-typing span:nth-child(2){animation-delay:.18s}.tutor-typing span:nth-child(3){animation-delay:.36s}@keyframes tutor-bounce{0%,60%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(-6px);opacity:1}}.tutor-input-wrap{flex-shrink:0;padding:.85rem clamp(1rem,6vw,4rem) 1rem;background:#fff;border-top:1px solid rgba(0,0,0,.06)}.tutor-input-row{display:flex;align-items:flex-end;gap:.6rem;background:#fafafa;border:1.5px solid rgba(0,0,0,.08);border-radius:14px;padding:.5rem .5rem .5rem .85rem;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.tutor-input-row:focus-within{background:#fff;border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1f}.tutor-input{flex:1;border:none;background:transparent;outline:none;resize:none;font-family:inherit;font-size:.92rem;line-height:1.5;color:var(--text-primary, #1f2937);padding:.45rem 0;max-height:200px;min-height:28px}.tutor-input::placeholder{color:var(--text-muted, #9ca3af)}.tutor-send-btn{width:38px;height:38px;border:none;border-radius:10px;background:linear-gradient(135deg,#16a34a,#059669);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .15s ease}.tutor-send-btn:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #16a34a59}.tutor-send-btn:active:not(:disabled){transform:scale(.96)}.tutor-send-btn:disabled{opacity:.4;cursor:not-allowed;background:#9ca3af}.tutor-input-hint{margin-top:.5rem;text-align:center;font-size:.72rem;color:var(--text-muted, #9ca3af)}[data-theme=dark] .tutor-page{background:#0f0f0f}[data-theme=dark] .tutor-header,[data-theme=dark] .tutor-sidebar,[data-theme=dark] .tutor-input-wrap{background:#1a1a1a;border-color:#ffffff0f}[data-theme=dark] .tutor-sidebar-toggle{background:#1e1e1e;border-color:#ffffff14}[data-theme=dark] .tutor-prompt{background:#1e1e1e;border-color:#ffffff0f}[data-theme=dark] .tutor-prompt:hover:not(:disabled){background:#232323;border-color:#16a34a}[data-theme=dark] .tutor-input-row{background:#1e1e1e;border-color:#ffffff14}[data-theme=dark] .tutor-input-row:focus-within{background:#232323}[data-theme=dark] .t-inline-code,[data-theme=dark] .tutor-inline-code{background:#ffffff14;color:#f0abfc}@media(max-width:720px){.tutor-sidebar{position:absolute;left:0;top:0;bottom:0;z-index:10}.tutor-sidebar-inner{width:260px}}.hw-page{max-width:1100px;margin:0 auto;padding:1.5rem 1.25rem 3rem}.hw-back{display:inline-flex;align-items:center;gap:.4rem;font-size:.84rem;color:var(--text-secondary, #6b7280);text-decoration:none;margin-bottom:1rem;font-weight:500;transition:color .15s ease}.hw-back:hover{color:var(--text-primary, #1f2937)}.hw-loading,.hw-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:6rem 1rem;color:var(--text-muted, #9ca3af)}.hw-spinner{width:32px;height:32px;border-radius:50%;border:3px solid rgba(22,163,74,.18);border-top-color:#16a34a;animation:hw-spin .8s linear infinite}.hw-spinner-sm{width:14px;height:14px;border-radius:50%;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;animation:hw-spin .7s linear infinite}@keyframes hw-spin{to{transform:rotate(360deg)}}.hw-hero{background:linear-gradient(135deg,#fff,#f7fffb);border:1px solid rgba(22,163,74,.15);border-radius:16px;padding:1.4rem 1.6rem;margin-bottom:1.25rem;box-shadow:0 1px 3px #00000008}.hw-hero-top{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:.6rem}.hw-title{margin:0 0 .5rem;font-size:1.6rem;font-weight:800;letter-spacing:-.02em;color:var(--text-primary, #111827)}.hw-breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem;margin-bottom:.6rem;font-size:.78rem}.hw-breadcrumb-course{font-weight:700;color:#16a34a}.hw-breadcrumb-lesson{display:inline-block;padding:.2rem .55rem;border-radius:12px;background:#3b82f61f;color:#2563eb;font-weight:700;font-variant-numeric:tabular-nums}.hw-breadcrumb-lesson-title{color:var(--text-secondary, #4b5563)}.hw-breadcrumb-sep{color:var(--text-muted, #9ca3af);opacity:.6}[data-theme=dark] .hw-breadcrumb-lesson{background:#3b82f62e;color:#60a5fa}.hw-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.85rem;font-size:.83rem;color:var(--text-secondary, #4b5563)}.hw-meta-item{display:inline-flex;align-items:center;gap:.35rem}.hw-overdue{color:#ef4444;font-weight:600}.hw-status-pill{display:inline-block;padding:.28rem .75rem;border-radius:16px;font-size:.72rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.hw-description{margin:0;color:var(--text-secondary, #4b5563);font-size:.92rem;line-height:1.55;white-space:pre-wrap}.hw-score-block{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0;text-align:right}.hw-score-num{font-size:2.1rem;font-weight:800;letter-spacing:-.03em;line-height:1}.hw-score-out{font-size:1rem;font-weight:600;color:var(--text-muted, #9ca3af);margin-left:.15rem}.hw-score-lbl{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted, #9ca3af);margin-top:.3rem}.hw-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;margin-bottom:1.25rem}.hw-card{background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:14px;padding:1.2rem 1.3rem;box-shadow:0 1px 3px #00000008}.hw-card-title{display:flex;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:.95rem;font-weight:700;color:var(--text-primary, #1f2937)}.hw-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;padding:1.5rem 1rem;border:2px dashed rgba(22,163,74,.3);border-radius:12px;background:#16a34a06;cursor:pointer;text-align:center;margin-bottom:.85rem;color:#16a34a;transition:background .15s ease,border-color .15s ease}.hw-dropzone:hover,.hw-dropzone-over{background:#16a34a0f;border-color:#16a34a8c}.hw-dropzone-uploading{pointer-events:none;opacity:.7}.hw-dropzone strong{font-size:.92rem;font-weight:700;display:block;color:var(--text-primary, #1f2937)}.hw-dropzone-hint{font-size:.72rem;color:var(--text-muted, #9ca3af);margin-top:.2rem;word-break:break-word}.hw-btn-upload{display:inline-flex;align-items:center;gap:.5rem;margin-top:.6rem;padding:.6rem 1.4rem;border:none;border-radius:9px;background:linear-gradient(135deg,#16a34a,#059669);color:#fff;font-family:inherit;font-size:.86rem;font-weight:700;cursor:pointer;transition:all .15s ease;box-shadow:0 2px 8px #16a34a40}.hw-btn-upload:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #16a34a66;background:linear-gradient(135deg,#15803d,#047857)}.hw-btn-upload:active:not(:disabled){transform:translateY(0)}.hw-btn-upload:disabled{background:#9ca3af;cursor:not-allowed;box-shadow:none;transform:none;color:#fff}[data-theme=dark] .hw-btn-upload:disabled{background:#4b5563}.hw-file-list{display:flex;flex-direction:column;gap:.4rem;margin-bottom:.75rem}.hw-file-item{display:flex;align-items:center;gap:.7rem;padding:.6rem .85rem;background:#fafafa;border:1px solid rgba(0,0,0,.05);border-radius:9px}.hw-file-icon{width:32px;height:32px;border-radius:8px;background:#16a34a1a;color:#16a34a;display:flex;align-items:center;justify-content:center;flex-shrink:0}.hw-file-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}.hw-file-name{font-size:.85rem;font-weight:600;color:var(--text-primary, #1f2937);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.hw-file-meta{font-size:.72rem;color:var(--text-muted, #9ca3af)}.hw-file-dl{width:28px;height:28px;border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary, #4b5563);background:transparent;text-decoration:none;transition:background .15s ease,color .15s ease;flex-shrink:0}.hw-file-dl:hover{background:#16a34a1a;color:#16a34a}.hw-no-files{text-align:center;padding:1rem;color:var(--text-muted, #9ca3af);font-size:.85rem}.hw-btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.65rem 1.2rem;border:none;border-radius:9px;background:linear-gradient(135deg,#16a34a,#059669);color:#fff;font-size:.88rem;font-weight:700;font-family:inherit;cursor:pointer;transition:all .15s ease}.hw-btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #16a34a52}.hw-btn-primary:disabled{opacity:.55;cursor:not-allowed}.hw-submit-btn{width:100%;margin-top:.5rem}.hw-info-box{margin-top:.75rem;padding:.7rem .95rem;background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:9px;color:#1e40af;font-size:.85rem;font-weight:500;text-align:center}.hw-ai-card{background:linear-gradient(135deg,#fefefe,#f0fdf4);border-color:#16a34a2e}.hw-ai-desc{font-size:.84rem;color:var(--text-secondary, #4b5563);margin:0 0 1rem;line-height:1.5}.hw-ai-types{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;margin-bottom:.85rem}.hw-ai-type{padding:.55rem .7rem;border:1.5px solid rgba(0,0,0,.08);background:#fff;border-radius:8px;font-family:inherit;font-size:.83rem;font-weight:600;color:var(--text-secondary, #4b5563);cursor:pointer;transition:all .15s ease;text-align:center}.hw-ai-type:hover:not(:disabled){border-color:#16a34a66;color:var(--text-primary, #1f2937)}.hw-ai-type.active{font-weight:700}.hw-ai-type:disabled{opacity:.55;cursor:not-allowed}.hw-btn-ai{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.7rem 1rem;border:none;border-radius:10px;background:linear-gradient(135deg,#8b5cf6,#6366f1);color:#fff;font-size:.88rem;font-weight:700;font-family:inherit;cursor:pointer;transition:all .15s ease}.hw-btn-ai:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #8b5cf666}.hw-btn-ai:disabled{opacity:.55;cursor:not-allowed}.hw-ai-result{margin-top:1rem;padding:1rem 1.1rem;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:10px;overflow:hidden;display:flex;flex-direction:column;max-height:480px}.hw-ai-result-head{flex-shrink:0}.hw-ai-result-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.6rem;padding-bottom:.6rem;border-bottom:1px solid rgba(0,0,0,.05)}.hw-ai-result-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted, #9ca3af)}.hw-ai-result-score{font-size:1.6rem;font-weight:800;letter-spacing:-.02em}.hw-ai-feedback{font-size:.86rem;line-height:1.55;color:var(--text-primary, #1f2937);white-space:pre-wrap;flex:1;min-height:0;overflow-y:auto;padding-right:.4rem}.hw-ai-feedback::-webkit-scrollbar{width:6px}.hw-ai-feedback::-webkit-scrollbar-track{background:transparent}.hw-ai-feedback::-webkit-scrollbar-thumb{background:#0000002e;border-radius:3px}.hw-ai-feedback::-webkit-scrollbar-thumb:hover{background:#00000052}[data-theme=dark] .hw-ai-feedback::-webkit-scrollbar-thumb{background:#ffffff2e}[data-theme=dark] .hw-ai-feedback::-webkit-scrollbar-thumb:hover{background:#ffffff52}.hw-ai-feedback p{margin:0 0 .5rem}.hw-ai-feedback p:last-child{margin-bottom:0}.hw-ai-disclaimer{margin-top:.85rem;padding-top:.6rem;border-top:1px solid rgba(0,0,0,.05);font-size:.74rem;color:var(--text-muted, #9ca3af);font-style:italic}.hw-feedback-card{background:linear-gradient(135deg,#fff,#fffbeb);border-color:#f59e0b33}.hw-instructor-feedback{font-size:.9rem;line-height:1.6;color:var(--text-primary, #1f2937);white-space:pre-wrap;max-height:420px;overflow-y:auto;padding-right:.4rem}.hw-instructor-feedback::-webkit-scrollbar{width:6px}.hw-instructor-feedback::-webkit-scrollbar-thumb{background:#0000002e;border-radius:3px}.hw-instructor-feedback::-webkit-scrollbar-thumb:hover{background:#00000052}.hw-instructor-feedback p{margin:0 0 .5rem}.hw-no-feedback{margin:0;color:var(--text-muted, #9ca3af);font-size:.88rem}[data-theme=dark] .hw-hero{background:linear-gradient(135deg,#1e1e1e,#1a2520);border-color:#16a34a40}[data-theme=dark] .hw-card{background:#1e1e1e;border-color:#ffffff0f}[data-theme=dark] .hw-ai-card{background:linear-gradient(135deg,#1e1e1e,#18261c);border-color:#16a34a40}[data-theme=dark] .hw-feedback-card{background:linear-gradient(135deg,#1e1e1e,#261f12);border-color:#f59e0b40}[data-theme=dark] .hw-file-item{background:#ffffff06;border-color:#ffffff0f}[data-theme=dark] .hw-ai-result,[data-theme=dark] .hw-ai-type{background:#232323;border-color:#ffffff14}@media(max-width:820px){.hw-grid{grid-template-columns:1fr}.hw-hero-top{flex-direction:column}.hw-score-block{align-items:flex-start}}.hwl-page{max-width:1100px;margin:0 auto;padding:1.5rem 1.25rem 3rem}.hwl-header{margin-bottom:1.25rem}.hwl-title{margin:0 0 .25rem;font-size:1.7rem;font-weight:800;letter-spacing:-.02em;color:var(--text-primary, #1f2937)}.hwl-sub{margin:0;color:var(--text-secondary, #6b7280);font-size:.9rem}.hwl-overdue-badge{color:#ef4444;font-weight:700}.hwl-toolbar{display:flex;gap:.6rem;margin-bottom:.85rem;flex-wrap:wrap}.hwl-toolbar>.hwl-search{flex:1;min-width:240px}.hwl-course-select{height:40px;padding:0 2.2rem 0 .9rem;border:1px solid rgba(0,0,0,.08);border-radius:10px;background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat right .85rem center;font-family:inherit;font-size:.86rem;font-weight:600;color:var(--text-primary, #1f2937);cursor:pointer;appearance:none;-webkit-appearance:none;min-width:200px;transition:border-color .18s ease,box-shadow .18s ease}.hwl-course-select:hover{border-color:#0000002e}.hwl-course-select:focus{outline:none;border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1f}[data-theme=dark] .hwl-course-select{background-color:#1e1e1e;border-color:#ffffff14;color:var(--text-primary, #e5e7eb)}.hwl-search{position:relative;display:flex;align-items:center;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:10px;padding:0 .85rem;height:40px;transition:border-color .18s ease,box-shadow .18s ease}.hwl-search:focus-within{border-color:#16a34a;box-shadow:0 0 0 3px #16a34a1f}.hwl-search>svg{color:var(--text-muted, #9ca3af);flex-shrink:0}.hwl-search input{flex:1;border:none;background:transparent;outline:none;padding:0 .6rem;font-size:.88rem;font-family:inherit;color:var(--text-primary, #1f2937)}.hwl-search-clear{border:none;background:transparent;color:var(--text-muted, #9ca3af);cursor:pointer;padding:4px;display:flex;align-items:center;border-radius:4px}.hwl-search-clear:hover{background:#0000000d;color:var(--text-primary, #1f2937)}[data-theme=dark] .hwl-search{background:#1e1e1e;border-color:#ffffff14}.hwl-chips{display:flex;flex-wrap:wrap;gap:.45rem;margin-bottom:1.25rem}.hwl-chip{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:20px;border:1px solid rgba(0,0,0,.08);background:#fff;color:var(--text-secondary, #4b5563);font-size:.78rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s ease}.hwl-chip:hover{border-color:#0000002e;color:var(--text-primary, #1f2937)}.hwl-chip.active{font-weight:700}.hwl-chip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.hwl-chip-count{background:#0000000f;padding:1px 7px;border-radius:10px;font-size:.7rem;font-weight:700;font-variant-numeric:tabular-nums;margin-left:.15rem}[data-theme=dark] .hwl-chip{background:#1e1e1e;border-color:#ffffff14}[data-theme=dark] .hwl-chip-count{background:#ffffff14}.hwl-loading,.hwl-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:5rem 1rem;text-align:center;color:var(--text-muted, #9ca3af)}.hwl-empty svg{opacity:.5;margin-bottom:.5rem}.hwl-empty h3{margin:0;font-size:1rem;font-weight:700;color:var(--text-primary, #1f2937)}.hwl-empty p{margin:0;font-size:.88rem}.hwl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.hwl-card{display:flex;flex-direction:column;gap:.6rem;padding:1.1rem 1.2rem;background:#fff;border:1px solid rgba(0,0,0,.06);border-radius:14px;cursor:pointer;box-shadow:0 1px 3px #00000008;transition:border-color .15s ease,box-shadow .15s ease}.hwl-card:hover{border-color:#16a34a66;box-shadow:0 6px 20px #16a34a1a}.hwl-card-overdue{border-color:#ef44444d;background:linear-gradient(135deg,#fff,#fef2f2)}.hwl-card-overdue:hover{border-color:#ef444499;box-shadow:0 6px 20px #ef444426}.hwl-card-top{display:flex;justify-content:space-between;align-items:center}.hwl-pill{display:inline-block;padding:.25rem .7rem;border-radius:16px;font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.hwl-points{font-size:.78rem;font-weight:700;color:var(--text-muted, #9ca3af)}.hwl-card-title{margin:0;font-size:1.02rem;font-weight:700;letter-spacing:-.01em;color:var(--text-primary, #1f2937);line-height:1.3}.hwl-card-meta-row{display:flex;flex-wrap:wrap;gap:.4rem;align-items:center}.hwl-course-tag{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .55rem;border-radius:12px;background:#16a34a1a;color:#16a34a;font-size:.72rem;font-weight:700;cursor:pointer;border:1px solid transparent;transition:all .15s ease;letter-spacing:.01em}.hwl-course-tag:hover{background:#16a34a2e;border-color:#16a34a59}[data-theme=dark] .hwl-course-tag{background:#16a34a2e;color:#4ade80}.hwl-lesson-num{display:inline-block;padding:.18rem .55rem;border-radius:12px;background:#3b82f61f;color:#2563eb;font-size:.7rem;font-weight:700;letter-spacing:.01em;font-variant-numeric:tabular-nums}[data-theme=dark] .hwl-lesson-num{background:#3b82f62e;color:#60a5fa}.hwl-lesson{display:inline-flex;align-items:center;gap:.35rem;font-size:.74rem;color:var(--text-muted, #9ca3af)}.hwl-desc{margin:0;font-size:.83rem;color:var(--text-secondary, #4b5563);line-height:1.45;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.hwl-card-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:.5rem;border-top:1px solid rgba(0,0,0,.04)}.hwl-due{display:inline-flex;align-items:center;gap:.3rem;font-size:.78rem;font-weight:600;color:var(--text-secondary, #4b5563)}.hwl-due-overdue{color:#ef4444}.hwl-due-none{color:var(--text-muted, #9ca3af);font-weight:500}.hwl-score{font-size:.86rem;font-weight:800;color:#16a34a;letter-spacing:-.01em}.hwl-card-actions{margin-top:.25rem}.hwl-btn-upload{display:inline-flex;align-items:center;gap:.4rem;width:100%;justify-content:center;padding:.55rem 1rem;border:none;border-radius:8px;background:linear-gradient(135deg,#16a34a,#059669);color:#fff;font-family:inherit;font-size:.83rem;font-weight:700;cursor:pointer;text-decoration:none;transition:all .15s ease;box-shadow:0 2px 6px #16a34a38}.hwl-btn-upload:hover{transform:translateY(-1px);box-shadow:0 4px 14px #16a34a66;background:linear-gradient(135deg,#15803d,#047857)}[data-theme=dark] .hwl-card{background:#1e1e1e;border-color:#ffffff0f}[data-theme=dark] .hwl-card-overdue{background:linear-gradient(135deg,#1e1e1e,#2a1818);border-color:#ef444466}[data-theme=dark] .hwl-card-bottom{border-top-color:#ffffff0a}@media(max-width:600px){.hwl-grid{grid-template-columns:1fr}}
