body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}#root{border:none;max-width:100%;min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}:root{--primary:#16a34a;--primary-dark:#15803d;--primary-light:#dcfce7;--bg:#f8fafc;--card:#fff;--text:#0f172a;--muted:#64748b;--border:#e2e8f0;--danger:#dc2626;--danger-bg:#fee2e2;--topbar-h:60px;--subbar-h:52px;--shadow-sm:0 1px 3px #0000000f;--shadow:0 4px 12px #0000000f;--shadow-lg:0 12px 32px #0000001a}html,body,#root{height:100%}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5}button{font:inherit;cursor:pointer}a{color:inherit}.splash{min-height:100vh;color:var(--muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner{border:3px solid var(--primary-light);border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.login-page{background:linear-gradient(135deg,#ecfdf5 0%,#f0f9ff 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--card);box-shadow:var(--shadow-lg);border-radius:20px;width:100%;max-width:440px;padding:40px 36px 32px}.login-brand{text-align:center;margin-bottom:28px}.logo-circle{background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:64px;height:64px;margin-bottom:14px;font-size:28px;font-weight:800;display:inline-flex;box-shadow:0 6px 20px #16a34a4d}.logo-circle.small{width:36px;height:36px;box-shadow:none;margin-bottom:0;font-size:18px}.login-brand h1{color:var(--primary-dark);margin-bottom:6px;font-size:24px}.login-brand p{color:var(--muted);font-size:13px}.login-form{flex-direction:column;gap:16px;display:flex}.field{flex-direction:column;gap:6px;display:flex}.field label{font-size:13px;font-weight:600}.field input,.input-with-action input{border:1.5px solid var(--border);background:var(--card);border-radius:10px;outline:none;width:100%;padding:11px 14px;font-size:14px;transition:border-color .15s,box-shadow .15s}.field input:focus,.input-with-action input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #16a34a26}.input-with-action{align-items:center;display:flex;position:relative}.input-with-action input{padding-right:60px}.input-with-action .ghost{color:var(--muted);background:0 0;border:none;border-radius:6px;padding:6px 8px;font-size:13px;font-weight:600;position:absolute;right:8px}.input-with-action .ghost:hover{color:var(--primary-dark);background:var(--primary-light)}.btn-primary{background:var(--primary);color:#fff;border:none;border-radius:10px;width:100%;padding:12px 16px;font-size:14px;font-weight:600;transition:background .15s,transform 50ms}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-primary:active:not(:disabled){transform:translateY(1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-outline{border:1.5px solid var(--border);color:var(--text);white-space:nowrap;background:0 0;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:600;transition:all .15s}.btn-outline:hover{border-color:var(--primary);color:var(--primary-dark);background:var(--primary-light)}.alert{border-radius:8px;padding:10px 12px;font-size:13px}.alert-error{background:var(--danger-bg);color:var(--danger);border:1px solid #fecaca}.login-foot{text-align:center;color:var(--muted);margin-top:6px;font-size:12px}.portal{flex-direction:column;min-height:100vh;display:flex}.portal-fullscreen{height:100vh;min-height:0;overflow:hidden}.topbar{background:var(--card);border-bottom:1px solid var(--border);height:var(--topbar-h);z-index:20;flex-shrink:0}.topbar-inner{justify-content:space-between;align-items:center;gap:16px;max-width:1400px;height:100%;margin:0 auto;padding:0 24px;display:flex}.brand{align-items:center;gap:10px;display:flex}.brand-name{color:var(--primary-dark);font-size:17px;font-weight:700}.user-menu{align-items:center;gap:12px;display:flex}.avatar{background:linear-gradient(135deg, var(--primary), var(--primary-dark));color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-weight:700;display:flex}.user-info{flex-direction:column;max-width:200px;line-height:1.2;display:flex}.user-info strong{white-space:nowrap;text-overflow:ellipsis;font-size:13px;overflow:hidden}.user-info span{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}@media (width<=700px){.user-info{display:none}}.main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:28px 24px 60px}.footer{border-top:1px solid var(--border);background:var(--card);text-align:center;color:var(--muted);margin-top:40px;padding:16px 24px;font-size:13px}.hero{margin-bottom:24px}.hero h1{margin-bottom:4px;font-size:26px}.hero p{color:var(--muted);font-size:14px}.course-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;display:grid}.course-card{background:var(--card);border:1px solid var(--border);text-align:left;border-radius:14px;flex-direction:column;padding:0;transition:transform .15s,box-shadow .15s,border-color .15s;display:flex;overflow:hidden}.course-card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary);transform:translateY(-2px)}.cover{aspect-ratio:16/9;background:var(--primary-light);position:relative;overflow:hidden}.cover img{object-fit:cover;width:100%;height:100%;display:block}.cover-fallback{width:100%;height:100%;color:var(--primary);justify-content:center;align-items:center;font-size:56px;display:flex}.level-badge{color:#fff;background:#0f172ad9;border-radius:999px;padding:4px 10px;font-size:11px;font-weight:600;position:absolute;top:10px;left:10px}.level-beginner{background:#16a34a}.level-intermediate{background:#2563eb}.level-advanced{background:#ea580c}.card-body{flex-direction:column;flex:1;gap:8px;padding:14px 16px 16px;display:flex}.card-body h3{font-size:15px;font-weight:700}.card-desc{color:var(--muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:13px;display:-webkit-box;overflow:hidden}.card-foot{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:auto;padding-top:8px;display:flex}.tag{border-radius:999px;padding:3px 10px;font-size:11px;font-weight:600}.tag-free{background:var(--primary-light);color:var(--primary-dark)}.tag-price{color:#92400e;background:#fef3c7}.card-cta{color:var(--primary-dark);font-size:13px;font-weight:600}.empty{text-align:center;color:var(--muted);padding:60px 24px}.empty-icon{margin-bottom:12px;font-size:56px}.empty h3{color:var(--text);margin-bottom:6px;font-size:16px}.empty p{font-size:14px}.empty .spinner{margin:0 auto 14px}.notice{text-align:center;color:#92400e;background:#fffbeb;border:1px dashed #fde68a;border-radius:16px;padding:60px 24px}.notice-icon{margin-bottom:10px;font-size:48px}.notice h3{color:#78350f;margin-bottom:6px}.notice p{max-width:480px;margin:0 auto;font-size:14px}.course-view{height:calc(100vh - var(--topbar-h));flex-direction:column;flex:1;display:flex;overflow:hidden}.course-subbar{height:var(--subbar-h);background:var(--card);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:16px;padding:0 20px;display:flex}.course-subbar-title{white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:15px;font-weight:700;overflow:hidden}.link-back{color:var(--primary-dark);white-space:nowrap;background:0 0;border:none;padding:0;font-size:14px;font-weight:600}.link-back:hover{text-decoration:underline}.mobile-only{display:none}@media (width<=900px){.mobile-only{display:inline-block}.course-subbar-title{font-size:14px}}.course-split{flex:1;min-height:0;display:flex}.sidebar{background:var(--card);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:360px;min-height:0;display:flex}.sidebar-head{border-bottom:1px solid var(--border);flex-shrink:0;padding:14px 18px}.sidebar-head h3{font-size:14px;font-weight:700}.sidebar-meta{color:var(--muted);font-size:12px}.sidebar-scroll{scrollbar-width:thin;flex:1;padding:8px 0;overflow-y:auto}.sidebar-scroll::-webkit-scrollbar{width:8px}.sidebar-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.sidebar-scroll::-webkit-scrollbar-thumb:hover{background:#cbd5e1}.s-section{border-bottom:1px solid var(--border)}.s-section:last-child{border-bottom:none}.s-section-head{text-align:left;width:100%;color:var(--text);background:0 0;border:none;align-items:center;gap:8px;padding:10px 16px;font-size:13px;font-weight:700;display:flex}.s-section-head:hover{background:var(--bg)}.s-section-title{flex:1}.chevron{color:var(--muted);flex-shrink:0;width:14px;font-size:11px}.s-chapter{padding-left:14px}.s-chapter-head{text-align:left;width:100%;color:var(--text);background:0 0;border:none;align-items:center;gap:8px;padding:8px 16px 8px 8px;font-size:13px;font-weight:600;display:flex}.s-chapter-head:hover{background:var(--bg)}.s-chapter-title{flex:1}.s-chapter-count{color:var(--muted);background:var(--bg);border-radius:999px;padding:2px 7px;font-size:11px}.s-lessons{list-style:none}.s-lesson{text-align:left;width:100%;color:var(--text);background:0 0;border:none;border-left:3px solid #0000;align-items:center;gap:10px;padding:8px 16px 8px 28px;font-size:13px;display:flex}.s-lesson:hover{background:var(--bg)}.s-lesson.active{background:var(--primary-light);border-left-color:var(--primary);color:var(--primary-dark);font-weight:600}.s-lesson-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:11px;display:inline-flex}.icon-video{color:#b91c1c;background:#fee2e2}.icon-document{color:#1e40af;background:#dbeafe}.icon-quiz{color:#92400e;background:#fef3c7}.icon-unknown{background:var(--border);color:var(--muted)}.s-lesson-title{word-break:break-word;flex:1}.content{background:var(--bg);flex:1;min-width:0;display:flex}.content-scroll{flex:1;padding:24px;overflow-y:auto}.content-scroll::-webkit-scrollbar{width:10px}.content-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px}.content-scroll::-webkit-scrollbar-thumb:hover{background:#cbd5e1}.lesson-view{background:var(--card);border:1px solid var(--border);max-width:960px;box-shadow:var(--shadow-sm);border-radius:16px;margin:0 auto;overflow:hidden}.lesson-view-head{border-bottom:1px solid var(--border);align-items:flex-start;gap:14px;padding:20px 24px;display:flex}.lesson-view-head .lesson-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:16px;display:inline-flex}.lesson-view-head h1{margin-bottom:4px;font-size:20px;line-height:1.3}.lesson-view-head p{color:var(--muted);font-size:14px}.lesson-view-body{padding:20px 24px 28px}.player{width:100%;box-shadow:var(--shadow);background:#000;border-radius:12px;overflow:hidden}.player-frame{aspect-ratio:16/9;width:100%;position:relative}.player-frame iframe{border:0;width:100%;height:100%;display:block;position:absolute;inset:0}.player-mask{pointer-events:none;background:#000;position:absolute}.player-mask-top{height:50px;top:0;left:0;right:0}.player-mask-logo{background:linear-gradient(#0000,#000000d9);width:90px;height:38px;bottom:0;right:0}@media (width<=900px){.course-split{position:relative}.sidebar{z-index:5;width:320px;box-shadow:var(--shadow-lg);transition:transform .2s;position:absolute;inset:0 auto 0 0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.content{width:100%}}
