*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f13;--surface: #18181f;--card: #1e1e27;--border: #2a2a36;--fg: #e8e8f0;--muted: #8888a0;--accent: #22c55e;--accent-dim: #16a34a;--danger: #ef4444;--danger-dim: #b91c1c;--warning: #f59e0b;--radius: 10px;--font: system-ui, -apple-system, sans-serif}body{background:var(--bg);color:var(--fg);font-family:var(--font);font-size:15px;line-height:1.5;min-height:100dvh}.app{display:flex;flex-direction:column;min-height:100dvh}.header{position:sticky;top:0;z-index:10;background:var(--surface);border-bottom:1px solid var(--border);padding:12px 16px;display:flex;flex-wrap:wrap;align-items:center;gap:12px}.header-logo{font-weight:700;font-size:1rem;white-space:nowrap}.tabs{display:flex;gap:4px;flex-wrap:wrap}.tab{padding:6px 14px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--muted);font-size:.9rem;cursor:pointer;transition:background .15s,color .15s}.tab:hover{background:var(--card);color:var(--fg)}.tab-active{background:var(--card);color:var(--fg);border-color:var(--accent)}.btn-logout{margin-left:auto;font-size:.8rem;min-height:32px;padding:4px 12px}.main{flex:1;padding:20px 16px;max-width:860px;width:100%;margin:0 auto}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:10px}.card-header{display:flex;align-items:center;justify-content:space-between;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.card-header-body{flex:1;display:flex;align-items:center;gap:8px;min-width:0}.card-header-body .card-title{flex:1;min-width:0}.card-header-actions{flex-shrink:0;display:flex;align-items:center}.card-thumb{width:40px;height:28px;object-fit:cover;border-radius:4px;flex-shrink:0}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;border:none;border-radius:8px;background:transparent;color:var(--muted);cursor:pointer;flex-shrink:0;-webkit-tap-highlight-color:transparent}.btn-icon:hover{background:var(--surface);color:var(--fg)}.btn-icon-danger:hover{color:var(--danger);background:#ef44441f}.card-title{font-weight:600;font-size:.95rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-meta{font-size:.8rem;color:var(--muted);flex-shrink:0}.card-chevron{color:var(--muted);font-size:.8rem;flex-shrink:0;transition:transform .2s}.card-chevron.open{transform:rotate(180deg)}.form{display:flex;flex-direction:column;gap:10px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border)}.field{display:flex;flex-direction:column;gap:4px}.field label{font-size:.8rem;color:var(--muted);font-weight:500}.field input,.field textarea{background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--fg);font-size:.9rem;padding:8px 10px;font-family:var(--font);width:100%}.field input:focus,.field textarea:focus{outline:none;border-color:var(--accent)}.field textarea{resize:vertical;min-height:70px}.admin-cover-block{display:flex;flex-direction:column;align-items:flex-start;gap:8px}.admin-cover-preview{width:120px;height:80px;object-fit:cover;border-radius:6px;border:1px solid var(--border)}.checkboxes{display:flex;flex-wrap:wrap;gap:8px}.checkbox-label{display:flex;align-items:center;gap:6px;font-size:.85rem;cursor:pointer;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:4px 10px}.checkbox-label input[type=checkbox]{accent-color:var(--accent);width:14px;height:14px}.btn-row{display:flex;gap:8px;flex-wrap:wrap;align-items:stretch;margin-top:4px}.btn-row .btn{flex:0 1 auto;min-width:0}.btn{display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;min-height:40px;padding:8px 16px;border-radius:8px;border:none;font-size:.875rem;font-weight:500;font-family:inherit;line-height:1.2;cursor:pointer;transition:opacity .15s;-webkit-tap-highlight-color:transparent}.btn:disabled{opacity:.5;cursor:default}.btn-primary{background:var(--accent);color:#052e16}.btn-primary:hover:not(:disabled){background:var(--accent-dim)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--danger-dim)}.btn-danger-muted{background:transparent;color:var(--muted);border:1px solid var(--border);font-size:.8125rem;font-weight:500;min-height:36px;padding:6px 12px}.btn-danger-muted:hover:not(:disabled){color:var(--danger);border-color:#ef444459;background:#ef44440f}.btn-secondary{background:var(--surface);color:var(--fg);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--card)}.btn-subtle{background:transparent;color:var(--muted);border:1px solid var(--border);font-weight:500}.btn-subtle:hover:not(:disabled){color:var(--fg);background:var(--surface);border-color:var(--border)}.section-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:8px}.section-top-main{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}.lesson-filter-hint{font-size:.85rem;font-weight:500}.lesson-filter{display:flex;flex-direction:column;gap:4px;min-width:180px;flex:1 1 160px;max-width:280px}.lesson-filter label{font-size:.75rem;color:var(--muted);font-weight:500}.lesson-filter select{background:var(--surface);border:1px solid var(--border);border-radius:8px;color:var(--fg);font-size:.875rem;padding:8px 10px;font-family:var(--font);cursor:pointer}.lesson-filter select:focus{outline:none;border-color:var(--accent)}.section-title{font-size:1.1rem;font-weight:700}.admin-video-lazy{position:relative;display:block;width:100%;max-width:480px;aspect-ratio:16 / 9;border-radius:8px;overflow:hidden;border:1px solid var(--border);padding:0;margin:0;cursor:pointer;background:var(--card);text-align:left;font:inherit;color:inherit}.admin-video-lazy:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.admin-video-lazy-poster{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.admin-video-lazy-fallback{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(145deg,#1a1d26,#0f1115)}.admin-video-lazy-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;background:#0f11158c;color:#f4f4f5;font-size:.875rem;font-weight:500}.admin-video-lazy-play{display:flex;align-items:center;justify-content:center;width:52px;height:52px;border-radius:50%;background:#ffffff1f;border:2px solid rgba(255,255,255,.35);font-size:1.25rem;padding-left:4px}.admin-video-iframe{display:block;width:100%;max-width:480px;aspect-ratio:16 / 9;border:none;border-radius:8px;background:#000}.admin-video-direct{display:block;width:100%;max-width:480px;aspect-ratio:16 / 9;border-radius:8px;background:#000}.admin-video-meta{margin-top:8px;font-size:.75rem;color:var(--muted);font-family:ui-monospace,monospace;word-break:break-all}.admin-lesson-video-wrap{width:100%;max-width:480px}.admin-lesson-video-wrap .video-iframe-bunny{border:none;width:100%;aspect-ratio:16 / 9;border-radius:8px;display:block;background:#000}.admin-lesson-video-wrap .video-processing{position:relative;width:100%;aspect-ratio:16 / 9;border-radius:8px;overflow:hidden;background:linear-gradient(145deg,#1a1d26,#0f1115,#151a22)}.admin-lesson-video-wrap .video-unavailable{position:relative;width:100%;aspect-ratio:16 / 9;border-radius:8px;overflow:hidden;background:linear-gradient(145deg,#1f1418,#0f1115 45%,#1a1518)}.admin-lesson-video-wrap .video-unavailable-shade{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#0f1115f0,#28141873 55%,#0f111580)}.admin-lesson-video-wrap .video-unavailable-inner{justify-content:center;gap:12px}.admin-lesson-video-wrap .video-unavailable-icon{color:#f87171;opacity:.95;margin-bottom:2px}.admin-lesson-video-wrap .video-unavailable-icon svg{display:block}.admin-lesson-video-wrap .video-processing-bg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;filter:blur(10px) brightness(.45);transform:scale(1.06)}.admin-lesson-video-wrap .video-processing-bg-fallback{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 50% 40%,#2d3748,#0f1115 70%)}.admin-lesson-video-wrap .video-processing-shade{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,#0f1115eb,#0f111559)}.admin-lesson-video-wrap .video-processing-inner{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:24px 20px;text-align:center;box-sizing:border-box}.admin-lesson-video-wrap .video-processing-spinner{width:44px;height:44px;border-radius:50%;border:3px solid rgba(255,255,255,.12);border-top-color:var(--accent);animation:admin-video-processing-spin .85s linear infinite}@keyframes admin-video-processing-spin{to{transform:rotate(360deg)}}.admin-lesson-video-wrap .video-processing-title{margin:0;font-size:1.05rem;font-weight:600;color:#f4f4f5;letter-spacing:.02em}.admin-lesson-video-wrap .video-processing-sub{margin:0;font-size:.875rem;color:#a1a1aa;line-height:1.45;max-width:260px}.badge{display:inline-block;padding:2px 8px;border-radius:20px;font-size:.75rem;font-weight:600}.badge-scheduled{background:#1e3a5f;color:#93c5fd}.badge-ready{background:#14532d;color:#86efac}.badge-completed{background:#27272a;color:#a1a1aa}.badge-missed{background:#450a0a;color:#fca5a5}.badge-NOT_STARTED{background:#27272a;color:#a1a1aa}.badge-IN_PROGRESS{background:#14532d;color:#86efac}.badge-COMPLETED{background:#1e3a5f;color:#93c5fd}.lesson-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:.85rem}.lesson-row:last-child{border-bottom:none}.lesson-row-title{flex:1}.lesson-row-time{color:var(--muted);white-space:nowrap}.nested{margin:10px 0 0;padding-left:8px;border-left:2px solid var(--border)}.login-gate{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center;padding:60px 20px}.login-title{font-size:1.2rem;font-weight:700}.login-widget{margin:10px 0;min-height:50px;display:flex;align-items:center;justify-content:center}.muted{color:var(--muted);font-size:.85rem}.error{color:var(--danger);font-size:.85rem}.empty{color:var(--muted);text-align:center;padding:32px 0}.spinner{color:var(--muted);text-align:center;padding:40px 0}
