@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--color-bg:#fafaf9;--color-surface:#fff;--color-surface-hover:#f5f5f4;--color-border:#e7e5e4;--color-border-light:#f5f5f4;--color-text-primary:#1c1917;--color-text-secondary:#78716c;--color-text-tertiary:#a8a29e;--color-primary:#10b981;--color-primary-hover:#059669;--color-primary-light:#d1fae5;--color-danger:#ef4444;--color-danger-hover:#dc2626;--color-danger-light:#fee2e2;--color-warning:#f59e0b;--color-warning-light:#fef3c7;--color-info:#3b82f6;--color-info-light:#dbeafe;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs:12px;--font-size-sm:13px;--font-size-base:14px;--font-size-md:16px;--font-size-lg:18px;--font-size-xl:20px;--font-size-2xl:24px;--font-size-3xl:30px;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.3;--line-height-normal:1.5;--line-height-relaxed:1.65;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--space-16:64px;--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #00000012, 0 2px 4px -2px #0000000d;--shadow-lg:0 10px 15px -3px #00000014, 0 4px 6px -4px #0000000a;--shadow-xl:0 20px 25px -5px #0000001a, 0 8px 10px -6px #0000000d;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-smooth:.3s ease;--z-dropdown:100;--z-sticky:200;--z-overlay:300;--z-modal:400;--z-toast:500;--sidebar-width:260px;--topnav-height:56px;--container-max:1280px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;scroll-behavior:smooth}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-regular);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg);min-height:100dvh}img,picture,video,canvas,svg{max-width:100%;display:block}input,button,textarea,select{font:inherit;color:inherit}button{cursor:pointer;background:0 0;border:none}a{color:var(--color-primary);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--color-primary-hover)}ul,ol{list-style:none}table{border-collapse:collapse;border-spacing:0}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}h1,h2,h3,h4,h5,h6{color:var(--color-text-primary);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);letter-spacing:-.02em}h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-md)}h6{font-size:var(--font-size-base);font-weight:var(--font-weight-medium)}p{color:var(--color-text-secondary);line-height:var(--line-height-relaxed);margin-bottom:var(--space-4)}p:last-child{margin-bottom:0}small{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}strong{font-weight:var(--font-weight-semibold)}hr{border:none;border-top:1px solid var(--color-border);margin:var(--space-6) 0}.container{width:100%;max-width:var(--container-max);padding:0 var(--space-4);margin:0 auto}@media (width>=640px){.container{padding:0 var(--space-6)}}@media (width>=1024px){.container{padding:0 var(--space-8)}}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.justify-start{justify-content:flex-start}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid{display:grid}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media (width>=640px){.sm\:grid-cols-2{grid-template-columns:repeat(2,1fr)}}@media (width>=768px){.md\:grid-cols-2{grid-template-columns:repeat(2,1fr)}.md\:grid-cols-3{grid-template-columns:repeat(3,1fr)}}@media (width>=1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,1fr)}.lg\:grid-cols-4{grid-template-columns:repeat(4,1fr)}}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.line-clamp-2{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden}.mt-auto{margin-top:auto}.ml-auto{margin-left:auto}.mr-auto{margin-right:auto}.mx-auto{margin-left:auto;margin-right:auto}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100dvh}.app-layout{min-height:100dvh;display:flex}.app-main{flex-direction:column;flex:1;min-width:0;display:flex}.app-content{padding:var(--space-6);flex:1;overflow-y:auto}@media (width>=1024px){.app-content{padding:var(--space-8)}}.page-header{margin-bottom:var(--space-6);justify-content:space-between;align-items:center;gap:var(--space-3);flex-wrap:wrap;display:flex}.page-header h1,.page-header h2{margin:0}.page-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.page-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-top:var(--space-1)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-6);transition:box-shadow var(--transition-base), transform var(--transition-base), border-color var(--transition-base)}.card:hover{box-shadow:var(--shadow-md);border-color:var(--color-border)}.card-interactive{cursor:pointer}.card-interactive:hover{box-shadow:var(--shadow-lg);transform:translateY(-1px)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-body{color:var(--color-text-secondary);font-size:var(--font-size-base)}.card-footer{margin-top:var(--space-4);padding-top:var(--space-4);border-top:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.card-compact{padding:var(--space-4)}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);font-size:var(--font-size-base);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;-webkit-user-select:none;user-select:none;transition:all var(--transition-base);border:1px solid #0000;height:36px;line-height:1;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.btn-primary:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-primary:active{transform:scale(.98)}.btn-secondary{background:var(--color-surface);color:var(--color-text-primary);border-color:var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:var(--color-text-tertiary)}.btn-danger{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-danger:hover{background:var(--color-danger-hover);border-color:var(--color-danger-hover)}.btn-ghost{color:var(--color-text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.btn-sm{height:30px;padding:var(--space-1) var(--space-3);font-size:var(--font-size-sm);border-radius:var(--radius-sm)}.btn-icon{border-radius:var(--radius-md);width:36px;height:36px;color:var(--color-text-secondary);transition:all var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:inline-flex}.btn-icon:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.btn-icon.btn-sm{width:30px;height:30px}.btn-group{gap:var(--space-2);display:flex}.label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-1);display:block}.input,.textarea,.select{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);height:38px;display:block}.input::placeholder,.textarea::placeholder{color:var(--color-text-tertiary)}.input:hover,.textarea:hover,.select:hover{border-color:var(--color-text-tertiary)}.input:focus,.textarea:focus,.select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.input-error,.input-error:hover,.input-error:focus{border-color:var(--color-danger)}.input-error:focus{box-shadow:0 0 0 3px var(--color-danger-light)}.textarea{resize:vertical;height:auto;min-height:100px;line-height:var(--line-height-normal)}.select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' stroke='%2378716C' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-group{margin-bottom:var(--space-5)}.form-error{font-size:var(--font-size-xs);color:var(--color-danger);margin-top:var(--space-1);align-items:center;gap:var(--space-1);display:flex}.form-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--space-1)}.checkbox-group,.radio-group{align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--font-size-base);color:var(--color-text-primary);display:flex}.badge{align-items:center;gap:var(--space-1);padding:2px var(--space-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-full);white-space:nowrap;background:var(--color-surface-hover);color:var(--color-text-secondary);line-height:1.5;display:inline-flex}.badge-success{background:var(--color-primary-light);color:var(--color-primary-hover)}.badge-warning{background:var(--color-warning-light);color:#92400e}.badge-danger{background:var(--color-danger-light);color:var(--color-danger)}.badge-info{background:var(--color-info-light);color:#1d4ed8}.badge-dot{border-radius:var(--radius-full);background:currentColor;flex-shrink:0;width:6px;height:6px}.modal-overlay{z-index:var(--z-modal);-webkit-backdrop-filter:blur(4px);animation:modalOverlayIn var(--transition-base) ease forwards;padding:var(--space-4);background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@keyframes modalOverlayIn{0%{opacity:0}to{opacity:1}}.modal-container{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90dvh;animation:modalSlideIn var(--transition-smooth) ease forwards;overflow-y:auto}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(12px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.modal-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0}.modal-body{padding:var(--space-6)}.modal-footer{justify-content:flex-end;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-light);display:flex}.modal-sm{max-width:400px}.modal-lg{max-width:720px}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);height:100dvh;z-index:var(--z-sticky);transition:transform var(--transition-smooth);flex-direction:column;display:flex;position:fixed;top:0;left:0;overflow-y:auto}.sidebar-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-light);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.sidebar-brand{align-items:center;gap:var(--space-3);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);display:flex}.sidebar-brand img{border-radius:var(--radius-sm);width:28px;height:28px}.sidebar-nav{padding:var(--space-3) var(--space-3);flex:1;overflow-y:auto}.sidebar-section{margin-bottom:var(--space-5)}.sidebar-section-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;padding:var(--space-2) var(--space-3);margin-bottom:var(--space-1)}.sidebar-link{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--color-text-secondary);transition:all var(--transition-fast);cursor:pointer;text-decoration:none;display:flex}.sidebar-link:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.sidebar-link.active{background:var(--color-primary-light);color:var(--color-primary-hover);font-weight:var(--font-weight-medium)}.sidebar-link-icon{opacity:.7;flex-shrink:0;width:18px;height:18px}.sidebar-link.active .sidebar-link-icon{opacity:1}.sidebar-footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border-light);flex-shrink:0}.sidebar-toggle{display:none}@media (width<=1023px){.sidebar{transform:translate(-100%)}.sidebar.sidebar-open{transform:translate(0)}.sidebar-backdrop{z-index:calc(var(--z-sticky) - 1);opacity:0;pointer-events:none;transition:opacity var(--transition-smooth);background:#0000004d;position:fixed;inset:0}.sidebar-backdrop.active{opacity:1;pointer-events:auto}.sidebar-toggle{display:flex}.app-main{margin-left:0}}@media (width>=1024px){.app-main{margin-left:var(--sidebar-width)}}.topnav{height:var(--topnav-height);padding:0 var(--space-6);background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:var(--z-sticky);flex-shrink:0;justify-content:space-between;align-items:center;display:flex;position:sticky;top:0}.topnav-left{align-items:center;gap:var(--space-3);display:flex}.topnav-center{flex:1;justify-content:center;display:flex}.topnav-right{align-items:center;gap:var(--space-2);display:flex}.topnav-breadcrumb{align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-tertiary);display:flex}.topnav-breadcrumb span{color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.topnav-breadcrumb-separator{color:var(--color-text-tertiary)}.table-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-lg);background:var(--color-surface);width:100%;overflow-x:auto}.table{border-collapse:collapse;width:100%;font-size:var(--font-size-base)}.table th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;background:var(--color-bg);border-bottom:1px solid var(--color-border);white-space:nowrap}.table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light);color:var(--color-text-primary);vertical-align:middle}.table tbody tr:last-child td{border-bottom:none}.table-striped tbody tr:nth-child(2n){background:var(--color-bg)}.table tbody tr{transition:background var(--transition-fast)}.table tbody tr.table-row-clickable{cursor:pointer}.empty-state{text-align:center;padding:var(--space-16) var(--space-6);flex-direction:column;justify-content:center;align-items:center;min-height:300px;display:flex}.empty-state-icon{background:var(--color-surface-hover);border-radius:var(--radius-full);width:56px;height:56px;color:var(--color-text-tertiary);margin-bottom:var(--space-5);justify-content:center;align-items:center;font-size:24px;display:flex}.empty-state-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.empty-state-description{font-size:var(--font-size-base);color:var(--color-text-tertiary);max-width:380px;margin-bottom:var(--space-6)}.empty-state-action{margin-top:var(--space-2)}.upload-zone{padding:var(--space-10) var(--space-6);border:2px dashed var(--color-border);border-radius:var(--radius-lg);background:var(--color-bg);cursor:pointer;transition:all var(--transition-base);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.upload-zone:hover{border-color:var(--color-primary);background:var(--color-primary-light)}.upload-zone.upload-zone-active{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:0 0 0 4px #10b9811a}.upload-zone-icon{background:var(--color-surface);border-radius:var(--radius-full);width:48px;height:48px;color:var(--color-primary);margin-bottom:var(--space-4);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;font-size:24px;display:flex}.upload-zone-text{font-size:var(--font-size-base);color:var(--color-text-secondary);margin-bottom:var(--space-1)}.upload-zone-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.upload-zone-text strong{color:var(--color-primary)}.progress-bar{background:var(--color-border-light);border-radius:var(--radius-full);width:100%;height:6px;overflow:hidden}.progress-bar-fill{background:var(--color-primary);border-radius:var(--radius-full);height:100%;transition:width var(--transition-smooth);min-width:0}.progress-bar-slim{height:4px}.progress-group{align-items:center;gap:var(--space-3);display:flex}.progress-group .progress-bar{flex:1}.progress-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-weight:var(--font-weight-medium);white-space:nowrap;text-align:right;min-width:36px}.lesson-tree{font-size:var(--font-size-base)}.lesson-tree-section{margin-bottom:var(--space-1)}.lesson-tree-header{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);cursor:pointer;font-weight:var(--font-weight-medium);color:var(--color-text-primary);transition:background var(--transition-fast);-webkit-user-select:none;user-select:none;display:flex}.lesson-tree-header:hover{background:var(--color-surface-hover)}.lesson-tree-toggle{width:18px;height:18px;color:var(--color-text-tertiary);transition:transform var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.lesson-tree-toggle.expanded{transform:rotate(90deg)}.lesson-tree-children{margin-left:var(--space-5);padding-left:var(--space-4);border-left:1px solid var(--color-border-light);transition:max-height var(--transition-smooth), opacity var(--transition-base);overflow:hidden}.lesson-tree-children.collapsed{opacity:0;max-height:0}.lesson-tree-children.expanded{opacity:1;max-height:2000px}.lesson-tree-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);text-decoration:none;display:flex;position:relative}.lesson-tree-item:before{content:"";left:calc(var(--space-4) * -1);width:var(--space-4);background:var(--color-border-light);height:1px;position:absolute;top:50%}.lesson-tree-item:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.lesson-tree-item.active{background:var(--color-primary-light);color:var(--color-primary-hover);font-weight:var(--font-weight-medium)}.lesson-tree-item-icon{opacity:.6;flex-shrink:0;width:16px;height:16px}.lesson-tree-item.active .lesson-tree-item-icon{opacity:1}.lesson-tree-item-status{border-radius:var(--radius-full);border:2px solid var(--color-border);width:16px;height:16px;transition:all var(--transition-fast);flex-shrink:0;margin-left:auto}.lesson-tree-item-status.completed{background:var(--color-primary);border-color:var(--color-primary)}.content-viewer{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.content-viewer-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.content-viewer-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.content-viewer-body{padding:var(--space-6)}.content-viewer-video{background:#000;width:100%;padding-bottom:56.25%;position:relative}.content-viewer-video iframe,.content-viewer-video video{border:none;width:100%;height:100%;position:absolute;inset:0}.content-viewer-audio{padding:var(--space-6);align-items:center;gap:var(--space-4);display:flex}.content-viewer-audio audio{width:100%}.content-viewer-notes{padding:var(--space-6);font-size:var(--font-size-base);line-height:var(--line-height-relaxed);color:var(--color-text-secondary)}.content-viewer-notes h1,.content-viewer-notes h2,.content-viewer-notes h3{margin-bottom:var(--space-3)}.content-viewer-notes p{margin-bottom:var(--space-4)}.content-viewer-notes ul,.content-viewer-notes ol{padding-left:var(--space-6);margin-bottom:var(--space-4);list-style:outside}.content-viewer-notes ol{list-style:decimal}.search-bar{width:100%;max-width:400px;position:relative}.search-bar-icon{left:var(--space-3);width:16px;height:16px;color:var(--color-text-tertiary);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-bar .input{background:var(--color-bg);border-color:var(--color-border-light);height:36px;font-size:var(--font-size-sm);padding-left:36px}.search-bar .input:focus{background:var(--color-surface);border-color:var(--color-primary)}.search-bar-shortcut{right:var(--space-3);font-size:var(--font-size-xs);color:var(--color-text-tertiary);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);pointer-events:none;padding:1px 6px;line-height:1.4;position:absolute;top:50%;transform:translateY(-50%)}.avatar{border-radius:var(--radius-full);font-weight:var(--font-weight-semibold);text-transform:uppercase;-webkit-user-select:none;user-select:none;width:36px;height:36px;font-size:var(--font-size-sm);background:var(--color-primary-light);color:var(--color-primary-hover);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.avatar-sm{width:28px;height:28px;font-size:var(--font-size-xs)}.avatar-lg{width:48px;height:48px;font-size:var(--font-size-md)}.avatar-xl{width:64px;height:64px;font-size:var(--font-size-xl)}.avatar-group{display:flex}.avatar-group .avatar{border:2px solid var(--color-surface);margin-left:-8px}.avatar-group .avatar:first-child{margin-left:0}.toast-container{top:var(--space-5);right:var(--space-5);z-index:var(--z-toast);gap:var(--space-3);pointer-events:none;flex-direction:column;display:flex;position:fixed}.toast{align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);pointer-events:auto;min-width:280px;max-width:420px;animation:toastIn var(--transition-smooth) ease forwards;display:flex}.toast-exiting{animation:toastOut var(--transition-base) ease forwards}@keyframes toastIn{0%{opacity:0;transform:translate(24px)}to{opacity:1;transform:translate(0)}}@keyframes toastOut{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(24px)}}.toast-icon{flex-shrink:0;width:20px;height:20px;margin-top:1px}.toast-icon.success{color:var(--color-primary)}.toast-icon.danger{color:var(--color-danger)}.toast-icon.warning{color:var(--color-warning)}.toast-icon.info{color:var(--color-info)}.toast-content{flex:1;min-width:0}.toast-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:2px}.toast-message{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal)}.toast-close{flex-shrink:0}.skeleton{background:var(--color-border-light);border-radius:var(--radius-md);position:relative;overflow:hidden}.skeleton:after{content:"";background:linear-gradient(90deg,#0000,#ffffff80,#0000);animation:1.5s infinite skeletonShimmer;position:absolute;inset:0}@keyframes skeletonShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.skeleton-text{height:14px;margin-bottom:var(--space-2)}.skeleton-text:last-child{width:70%}.skeleton-heading{width:50%;height:22px;margin-bottom:var(--space-4)}.skeleton-avatar{border-radius:var(--radius-full);width:36px;height:36px}.skeleton-card{height:160px}.skeleton-image{border-radius:var(--radius-lg);height:180px}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);gap:var(--space-2);transition:box-shadow var(--transition-base), border-color var(--transition-base);flex-direction:column;display:flex}.stat-card:hover{box-shadow:var(--shadow-sm)}.stat-card-header{justify-content:space-between;align-items:center;display:flex}.stat-card-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.stat-card-icon{border-radius:var(--radius-md);background:var(--color-primary-light);width:36px;height:36px;color:var(--color-primary);justify-content:center;align-items:center;font-size:18px;display:flex}.stat-card-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);letter-spacing:-.02em;line-height:1}.stat-card-change{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);align-items:center;gap:var(--space-1);display:flex}.stat-card-change.positive{color:var(--color-primary)}.stat-card-change.negative{color:var(--color-danger)}.hide-mobile{display:none}@media (width>=640px){.hide-mobile{display:initial}}.show-mobile{display:initial}@media (width>=640px){.show-mobile{display:none}}@media (width>=768px){.md\:flex{display:flex}.md\:hidden{display:none}}@media (width>=1024px){.lg\:flex{display:flex}.lg\:hidden{display:none}}*{scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.login-page{background:var(--color-bg);min-height:100dvh;padding:var(--space-4);justify-content:center;align-items:center;display:flex}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:400px;padding:var(--space-10);box-shadow:var(--shadow-lg)}.login-logo{margin:0 auto var(--space-5);border-radius:var(--radius-lg)}.login-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-2)}.login-subtitle{font-size:var(--font-size-base);color:var(--color-text-tertiary)}.login-form .btn{width:100%;height:40px;font-size:var(--font-size-base)}.login-divider{align-items:center;gap:var(--space-3);color:var(--color-text-tertiary);font-size:var(--font-size-sm);display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.login-footer{text-align:center;margin-top:var(--space-6);font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.login-footer a{color:var(--color-primary);font-weight:var(--font-weight-medium)}.btn-oauth{justify-content:center;align-items:center;gap:var(--space-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;height:40px;font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);display:flex}.btn-oauth:hover{background:var(--color-surface-hover);border-color:var(--color-text-tertiary)}.btn-oauth img,.btn-oauth svg{width:18px;height:18px}.fade-in{animation:fadeIn var(--transition-smooth) ease forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slide-up{animation:slideUp var(--transition-smooth) ease forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.pulse{animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.divider{border:none;border-top:1px solid var(--color-border);margin:var(--space-4) 0}.dropdown-menu{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);min-width:180px;box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);padding:var(--space-1) 0;animation:dropdownIn var(--transition-fast) ease forwards;position:absolute;top:100%;right:0}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-4px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.dropdown-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);display:flex}.dropdown-item:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.dropdown-item.danger{color:var(--color-danger)}.dropdown-item.danger:hover{background:var(--color-danger-light)}.dropdown-divider{background:var(--color-border-light);height:1px;margin:var(--space-1) 0}[data-tooltip]{position:relative}[data-tooltip]:after{content:attr(data-tooltip);padding:var(--space-1) var(--space-2);background:var(--color-text-primary);color:#fff;font-size:var(--font-size-xs);border-radius:var(--radius-sm);white-space:nowrap;pointer-events:none;opacity:0;transition:opacity var(--transition-fast);z-index:var(--z-dropdown);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%)}[data-tooltip]:hover:after{opacity:1}::selection{background:var(--color-primary-light);color:var(--color-primary-hover)}.disabled{opacity:.5;pointer-events:none;cursor:not-allowed}.loading-overlay{z-index:var(--z-overlay);border-radius:inherit;background:#fafaf9cc;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.loading-spinner{border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:var(--radius-full);width:24px;height:24px;animation:.6s linear infinite spin}.notification-dot{background:var(--color-danger);border-radius:var(--radius-full);border:2px solid var(--color-surface);width:8px;height:8px;position:absolute;top:-2px;right:-2px}.tabs{border-bottom:1px solid var(--color-border);gap:0;display:flex;overflow-x:auto}.tab{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000}.tab:hover{color:var(--color-text-primary)}.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.chip{align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-3);background:var(--color-surface-hover);border:1px solid var(--color-border-light);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);display:inline-flex}.chip-close{border-radius:var(--radius-full);cursor:pointer;width:14px;height:14px;transition:background var(--transition-fast);justify-content:center;align-items:center;display:flex}.chip-close:hover{background:var(--color-border)}.dashboard-grid{gap:var(--space-4);grid-template-columns:1fr;display:grid}@media (width>=640px){.dashboard-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.dashboard-grid{grid-template-columns:repeat(4,1fr)}}.courses-grid{gap:var(--space-5);grid-template-columns:1fr;display:grid}@media (width>=640px){.courses-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.courses-grid{grid-template-columns:repeat(3,1fr)}}.course-view{min-height:calc(100vh - var(--topnav-height));min-height:calc(100dvh - var(--topnav-height));flex-direction:column;display:flex}.course-view__loading{flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.course-view__sidebar{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:var(--space-4) var(--space-5);flex-shrink:0}.course-view__back{align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);margin-bottom:var(--space-4);transition:color var(--transition-fast);display:inline-flex}.course-view__back:hover{color:var(--color-text-primary)}.course-view__sidebar-header{margin-bottom:var(--space-4)}.course-view__course-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--space-1);line-height:var(--line-height-tight)}.course-view__course-desc{font-size:var(--font-size-sm);color:var(--color-text-tertiary);line-height:var(--line-height-normal);margin-bottom:0}.course-view__mobile-toggle{align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast);display:flex}.course-view__mobile-toggle:hover{background:var(--color-border-light);color:var(--color-text-primary)}.course-view__mobile-toggle span:first-of-type{text-align:left;flex:1}.course-view__lesson-panel{max-height:0;transition:max-height var(--transition-smooth), opacity var(--transition-base);opacity:0;overflow:hidden}.course-view__lesson-panel--open{opacity:1;max-height:2000px;margin-top:var(--space-3)}.course-view__main{padding:var(--space-4);flex:1;overflow-y:auto}@media (width>=1024px){.course-view{flex-direction:row}.course-view__sidebar{width:280px;min-width:280px;height:calc(100vh - var(--topnav-height));height:calc(100dvh - var(--topnav-height));border-bottom:none;border-right:1px solid var(--color-border);padding:var(--space-5);top:var(--topnav-height);position:sticky;overflow-y:auto}.course-view__mobile-toggle{display:none}.course-view__lesson-panel,.course-view__lesson-panel--open{opacity:1;max-height:none;margin-top:0;overflow:visible}.course-view__main{padding:var(--space-6)}}@media (width>=1280px){.course-view__main{padding:var(--space-8)}}.student-main{flex:1;overflow-y:auto}.student-main>.fade-in{padding:var(--space-6)}@media (width>=1024px){.student-main>.fade-in{padding:var(--space-8)}}.student-layout{flex-direction:column;min-height:100dvh;display:flex}.student-layout .topnav{flex-shrink:0}.topnav__left{align-items:center;display:flex}.topnav__logo{align-items:center;gap:var(--space-2);font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);text-decoration:none;display:flex}.topnav__logo:hover{color:var(--color-text-primary)}.topnav__logo-icon{font-size:var(--font-size-xl)}.topnav__center{align-items:center;gap:var(--space-1);display:flex}.topnav__link{align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);transition:all var(--transition-fast);text-decoration:none;display:flex}.topnav__link:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.topnav__link--active{background:var(--color-primary-light);color:var(--color-primary-hover)}.topnav__right{align-items:center;gap:var(--space-3);display:flex}.topnav__user{align-items:center;gap:var(--space-2);display:flex}.topnav__user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}@media (width<=639px){.topnav__user-name{display:none}}.form-error-banner{padding:var(--space-3) var(--space-4);background:var(--color-danger-light);color:var(--color-danger);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.page-loader{justify-content:center;align-items:center;min-height:100dvh;display:flex}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:var(--radius-full);width:32px;height:32px;animation:.7s linear infinite spin}.admin-layout{min-height:100dvh;display:flex}.admin-main{background:var(--color-bg);flex:1;min-width:0}@media (width>=1024px){.admin-main{margin-left:var(--sidebar-width)}}.sidebar__header{padding:var(--space-5);border-bottom:1px solid var(--color-border-light);flex-shrink:0}.sidebar__logo{align-items:center;gap:var(--space-2);display:flex}.sidebar__logo-icon{font-size:var(--font-size-xl)}.sidebar__logo-text{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.sidebar__nav{padding:var(--space-3);gap:var(--space-1);flex-direction:column;flex:1;display:flex;overflow-y:auto}.sidebar__link{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--color-text-secondary);transition:all var(--transition-fast);text-decoration:none;display:flex}.sidebar__link:hover{background:var(--color-surface-hover);color:var(--color-text-primary)}.sidebar__link--active{background:var(--color-primary-light);color:var(--color-primary-hover);font-weight:var(--font-weight-medium)}.sidebar__footer{padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border-light);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.sidebar__user{align-items:center;gap:var(--space-3);min-width:0;display:flex}.sidebar__user-info{flex-direction:column;min-width:0;display:flex}.sidebar__user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.sidebar__user-role{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.sidebar--open{transform:translate(0)!important}.sidebar-backdrop{z-index:calc(var(--z-sticky) - 1);background:#0000004d;position:fixed;inset:0}.sidebar-toggle{top:var(--space-4);left:var(--space-4);z-index:calc(var(--z-sticky) + 1);display:none;position:fixed}@media (width<=1023px){.sidebar-toggle{display:flex}}.modal-container--sm{max-width:400px}.modal-container--md{max-width:520px}.modal-container--lg{max-width:720px}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0}.btn-full{width:100%}.avatar{border-radius:var(--radius-full);background:var(--color-primary-light);color:var(--color-primary-hover);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.avatar--sm{width:32px;height:32px;font-size:var(--font-size-xs)}.avatar--md{width:40px;height:40px}.avatar--lg{width:48px;height:48px;font-size:var(--font-size-md)}.badge--sm{padding:1px 6px;font-size:10px}.table{border-collapse:collapse;width:100%}.table thead{background:var(--color-surface-hover)}.table th{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.04em}.table td{border-top:1px solid var(--color-border-light)}.table tbody tr:hover{background:var(--color-surface-hover)}.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.text-sm{font-size:var(--font-size-sm)}.prose h1,.prose h2,.prose h3,.prose h4{margin-top:1.5em;margin-bottom:.5em}.prose p{color:var(--color-text-primary);margin-bottom:1em;line-height:1.7}.prose ul,.prose ol{margin-bottom:1em;padding-left:1.5em}.prose ul{list-style:outside}.prose ol{list-style:decimal}.prose li{margin-bottom:.25em}.prose a{color:var(--color-primary);text-decoration:underline}.prose strong{font-weight:var(--font-weight-semibold)}.prose blockquote{border-left:3px solid var(--color-primary);padding-left:var(--space-4);margin:var(--space-4) 0;color:var(--color-text-secondary);font-style:italic}.content-viewer__title{font-size:var(--font-size-xl);margin-bottom:var(--space-5)}.content-viewer__video{border-radius:var(--radius-lg);background:#000;height:0;padding-bottom:56.25%;position:relative;overflow:hidden}.content-viewer__video iframe{border-radius:var(--radius-lg);border:none;width:100%;height:100%;position:absolute;top:0;left:0}.content-viewer__audio{padding:var(--space-4)}.content-viewer__audio audio{width:100%;margin-top:var(--space-3)}.content-viewer__file-name{font-weight:var(--font-weight-medium);margin-bottom:var(--space-2);color:var(--color-text-primary)}.content-viewer__pdf-frame{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;height:70vh}.content-viewer__doc-actions{margin-top:var(--space-4)}.content-viewer__doc-download{text-align:center;padding:var(--space-10) var(--space-4)}.content-viewer__notes{padding:var(--space-2) 0}.content-viewer--empty{justify-content:center;align-items:center;min-height:200px;display:flex}.login-page{min-height:100dvh;padding:var(--space-4);background:var(--color-bg);justify-content:center;align-items:center;display:flex}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-8);width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.login-header{text-align:center;margin-bottom:var(--space-8)}.login-logo{justify-content:center;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);display:flex}.login-logo__icon{font-size:28px}.login-logo__text{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin:0}.login-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-base);margin:0}.login-form{gap:var(--space-1);flex-direction:column;display:flex}.login-footer{margin-top:var(--space-6);text-align:center;font-size:var(--font-size-xs);color:var(--color-text-tertiary);line-height:1.6}.skeleton{background:linear-gradient(90deg, var(--color-surface-hover) 25%, var(--color-border-light) 50%, var(--color-surface-hover) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.ltree{font-size:var(--font-size-base);margin:0;padding:0;list-style:none}.ltree--root{padding:var(--space-1) 0}.ltree__item{list-style:none}.ltree__row{border-radius:var(--radius-md);cursor:pointer;-webkit-user-select:none;user-select:none;border-left:3px solid #0000;align-items:center;gap:8px;margin-bottom:1px;padding:7px 10px;transition:all .15s;display:flex;position:relative}.ltree__row:hover{background:var(--color-surface-hover)}.ltree__row--selected{background:var(--color-primary-light);border-left-color:var(--color-primary)}.ltree__row--selected .ltree__label{font-weight:var(--font-weight-medium);color:var(--color-primary-hover)}.ltree__row--selected .ltree__icon{color:var(--color-primary)!important}.ltree__row--folder .ltree__label{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.ltree__toggle{width:18px;height:18px;color:var(--color-text-tertiary);flex-shrink:0;justify-content:center;align-items:center;transition:transform .15s;display:flex}.ltree__toggle--hidden{visibility:hidden}.ltree__toggle--open{transform:rotate(90deg)}.ltree__icon{width:18px;height:18px;color:var(--color-text-tertiary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.ltree__icon--video{color:#ef4444}.ltree__icon--audio{color:#8b5cf6}.ltree__icon--document{color:#f59e0b}.ltree__icon--notes{color:#3b82f6}.ltree__icon--folder{color:var(--color-text-tertiary)}.ltree__label{white-space:normal;word-break:break-word;min-width:0;font-size:var(--font-size-sm);color:var(--color-text-secondary);flex:1;line-height:1.3}.ltree__count{background:var(--color-surface-hover);color:var(--color-text-tertiary);border-radius:var(--radius-full);min-width:20px;height:18px;font-size:11px;font-weight:var(--font-weight-medium);flex-shrink:0;justify-content:center;align-items:center;padding:0 6px;display:inline-flex}.ltree__children{border-left:1px solid var(--color-border-light);margin-left:14px;padding-left:14px}.cv__type-label{font-size:12px;font-weight:var(--font-weight-medium);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-4);background:var(--color-surface-hover);border-radius:var(--radius-full);align-items:center;gap:6px;padding:4px 10px;display:inline-flex}.cv__video{border-radius:var(--radius-lg);height:0;box-shadow:var(--shadow-md);background:#000;padding-bottom:56.25%;position:relative;overflow:hidden}.cv__video iframe{border:none;width:100%;height:100%;position:absolute;inset:0}.cv__audio-card{background:var(--color-surface-hover);border-radius:var(--radius-lg);padding:var(--space-5);gap:var(--space-3);flex-direction:column;display:flex}.cv__audio-accent{height:4px;margin-bottom:var(--space-1);background:linear-gradient(90deg,#8b5cf6,#ec4899);border-radius:2px}.cv__audio-meta{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);align-items:center;gap:8px;display:flex}.cv__audio-card audio{border-radius:var(--radius-md);width:100%}.cv__doc-card{border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-8);text-align:center;align-items:center;gap:var(--space-3);flex-direction:column;display:flex}.cv__doc-icon{background:var(--color-warning-light);border-radius:var(--radius-xl);color:#f59e0b;justify-content:center;align-items:center;width:64px;height:64px;display:flex}.cv__doc-name{font-weight:var(--font-weight-semibold);font-size:var(--font-size-md);color:var(--color-text-primary);margin:0}.cv__doc-size{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin:0}.cv__pdf-embed{border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;height:75vh;overflow:hidden}.cv__pdf-embed iframe{border:none;width:100%;height:100%}.cv__notes{padding:var(--space-2) 0}.cv__section-info{text-align:center;padding:var(--space-12) var(--space-6);color:var(--color-text-tertiary)}.cv__section-info svg{opacity:.4;margin:0 auto 12px}.cv__section-info p{color:var(--color-text-tertiary);margin:0}.cv__empty{text-align:center;padding:var(--space-12) var(--space-6);color:var(--color-text-tertiary)}.cv__empty svg{opacity:.3;margin:0 auto 12px}.cv__empty p{color:var(--color-text-tertiary);margin:0}.editor-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex-direction:column;display:flex;overflow:hidden}.editor-panel__header{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light);background:#f5f5f480;justify-content:space-between;align-items:center;display:flex}.editor-panel__header h3{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-secondary);margin:0}.editor-panel__body{padding:var(--space-4);flex:1}.editor-panel__body--flush{padding:0}.editor-detail{min-height:300px}.editor-detail__toolbar{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border-light);justify-content:space-between;align-items:center;display:flex}.editor-detail__content{padding:var(--space-5)}.course-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-5);cursor:pointer;flex-direction:column;transition:all .2s;display:flex;position:relative;overflow:hidden}.course-card:before{content:"";background:linear-gradient(90deg, var(--color-primary), var(--color-info));opacity:0;height:3px;transition:opacity .2s;position:absolute;top:0;left:0;right:0}.course-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.course-card:hover:before{opacity:1}.course-card__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0 0 var(--space-2) 0;color:var(--color-text-primary)}.course-card__desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0 0 var(--space-4) 0;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1;display:-webkit-box;overflow:hidden}.course-card__footer{padding-top:var(--space-3);border-top:1px solid var(--color-border-light);justify-content:space-between;align-items:center;margin-top:auto;display:flex}.course-card__stat{font-size:var(--font-size-xs);color:var(--color-text-tertiary);align-items:center;gap:4px;display:flex}
