*{box-sizing:border-box;margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans KR,sans-serif}html,body,#root{height:100%}body{font-size:14px;background:#fff;color:#222}.wrap{display:flex;flex-direction:column;height:100dvh;background:#fff;font-size:14px}.topbar{background:#1a73e8;color:#fff;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0;padding-top:max(14px,env(safe-area-inset-top))}.topbar-left h1{font-size:17px;font-weight:700;letter-spacing:-.3px}.topbar-left p{font-size:11px;opacity:.85;margin-top:2px;font-weight:400}.topbar-right button{padding:7px 14px;border-radius:8px;border:1.5px solid rgba(255,255,255,.7);background:transparent;color:#fff;font-size:12px;cursor:pointer;font-weight:600;display:flex;align-items:center;gap:5px}.topbar-right button:hover{background:#ffffff26}.body{display:flex;flex:1;overflow:hidden}.lnb{width:168px;flex-shrink:0;border-right:1px solid #e8e8e8;background:#fafafa;display:flex;flex-direction:column;overflow-y:auto}.lnb-section{padding:14px 14px 8px}.lnb-label{font-size:10px;font-weight:700;color:#aaa;letter-spacing:.6px;text-transform:uppercase;margin-bottom:8px}.lnb-btn{display:flex;align-items:center;width:100%;padding:7px 10px;border-radius:8px;border:none;background:transparent;font-size:13px;color:#555;cursor:pointer;text-align:left;font-weight:500;transition:all .12s}.lnb-btn:hover{background:#eee;color:#111}.lnb-btn.on{background:#1a73e8;color:#fff;font-weight:600}.lnb-divider{height:1px;background:#e8e8e8;margin:4px 14px}.lnb-subject-btn{display:flex;align-items:center;width:100%;padding:6px 10px;border-radius:7px;border:none;background:transparent;font-size:12px;color:#666;cursor:pointer;text-align:left;transition:all .12s;gap:6px}.lnb-subject-btn:hover{background:#eee;color:#111}.lnb-subject-btn.on{background:#e8f0fe;color:#1a73e8;font-weight:600}.lnb-subject-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.content{flex:1;display:flex;flex-direction:column;overflow:hidden;background:#fff}.content-header{padding:14px 20px 10px;border-bottom:1px solid #f0f0f0;flex-shrink:0}.content-header-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.breadcrumb{font-size:12px;color:#999}.breadcrumb span{color:#1a73e8;font-weight:600}.search-row{display:flex;align-items:center;gap:8px}.search-box{position:relative;flex:1}.search-box input{width:100%;padding:7px 11px 7px 30px;border:1px solid #ddd;border-radius:8px;font-size:13px;color:#111;background:#fafafa;outline:none}.search-box input:focus{border-color:#1a73e8;background:#fff}.search-icon-pos{position:absolute;left:9px;top:50%;transform:translateY(-50%);font-size:13px;color:#bbb}.count-chip{font-size:11px;color:#888;background:#f5f5f5;padding:4px 10px;border-radius:20px;white-space:nowrap}.list-area{flex:1;overflow-y:auto;padding:0 20px 16px}.list-item{display:flex;align-items:center;padding:11px 14px;border-bottom:1px solid #f3f3f3;gap:12px;transition:background .1s}.list-item:hover{background:#fafafa}.list-num{font-size:11px;color:#ccc;width:22px;text-align:right;flex-shrink:0;font-weight:500}.list-level{font-size:10px;padding:2px 6px;border-radius:20px;font-weight:700;flex-shrink:0}.lv초{background:#fff3e0;color:#e65100}.lv중{background:#e8f5e9;color:#1b5e20}.lv고{background:#e3f2fd;color:#0d47a1}.row-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;display:inline-block}.list-name{flex:1;font-size:13px;color:#222;font-weight:500;line-height:1.4}.list-btns{display:flex;gap:5px;flex-shrink:0}.btn-lesson{padding:5px 11px;border-radius:6px;border:1px solid #ddd;background:#fff;font-size:11px;color:#555;cursor:pointer;font-weight:500;white-space:nowrap}.btn-lesson:hover{background:#f5f5f5;border-color:#bbb}.btn-install{padding:5px 11px;border-radius:6px;border:1px solid #1a73e8;background:#fff;font-size:11px;color:#1a73e8;cursor:pointer;font-weight:600;white-space:nowrap}.btn-install:hover{background:#e8f0fe}.no-result{padding:60px;text-align:center;color:#bbb;font-size:14px}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:none;align-items:flex-end;justify-content:center;z-index:999}.overlay.open{display:flex}.sheet{background:#fff;border-radius:20px 20px 0 0;padding:24px 22px calc(22px + env(safe-area-inset-bottom));width:100%;max-width:480px}.sheet h3{font-size:15px;font-weight:700;margin-bottom:16px;color:#111}.irow{display:flex;align-items:flex-start;gap:11px;padding:9px 0;border-bottom:1px solid #f0f0f0}.irow:last-of-type{border:none;padding-bottom:0}.iicon{font-size:18px;line-height:1.4;flex-shrink:0}.itext{font-size:13px;color:#555;line-height:1.6}.itext b{color:#111;font-weight:600;display:block}.itext .hl{color:#1a73e8;font-size:12px;font-weight:600}.sheet-close{width:100%;margin-top:10px;padding:11px;border-radius:10px;border:1px solid #ddd;background:#fff;font-size:14px;cursor:pointer;color:#666}.sheet-close:hover{background:#f5f5f5}.sheet-install{width:100%;margin-bottom:14px;padding:13px;border-radius:11px;border:none;background:#1a73e8;color:#fff;font-size:14px;font-weight:700;cursor:pointer}.sheet-install:hover{background:#1666cf}.sheet-reset{width:100%;margin-top:16px;padding:10px;border-radius:10px;border:1px solid #f0c5c0;background:#fff;font-size:12px;cursor:pointer;color:#d93025;font-weight:600}.sheet-reset:hover{background:#fdecea}.itext code{background:#eef1f6;padding:1px 5px;border-radius:5px;font-size:11px}.guidebox{background:#e8f0fe;border:1px solid #d2e3fc;border-radius:11px;padding:14px 16px}.guidebox b{display:block;color:#1a4fa0;font-size:13px;margin-bottom:6px}.guidebox p{font-size:13px;color:#333;line-height:1.7}.guidebox code{background:#fff;padding:1px 5px;border-radius:5px;font-size:11px}.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%);background:#222;color:#fff;font-size:13px;padding:11px 18px;border-radius:10px;box-shadow:0 6px 20px #00000040;z-index:1000;max-width:90vw;text-align:center;animation:toastIn .2s ease}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,8px)}to{opacity:1;transform:translate(-50%)}}.dbg{position:fixed;left:8px;right:8px;bottom:8px;background:#111;color:#eee;font-size:12px;line-height:1.6;padding:12px 14px;border-radius:10px;z-index:1001;font-family:ui-monospace,Menlo,Consolas,monospace;box-shadow:0 6px 20px #0006}.dbg b{display:block;margin-bottom:6px;color:#fff}.viewer{display:flex;flex-direction:column;height:100dvh}.viewer-bar{display:flex;align-items:center;gap:12px;background:#1a73e8;color:#fff;padding:10px 14px;flex-shrink:0;padding-top:max(10px,env(safe-area-inset-top))}.viewer-back{background:#ffffff26;border:none;color:#fff;font-size:13px;font-weight:600;padding:6px 12px;border-radius:8px;cursor:pointer}.viewer-title{flex:1;font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.viewer-ext{color:#fff;font-size:12px;opacity:.85;text-decoration:none;white-space:nowrap}.viewer-frame{flex:1;width:100%;border:none}.viewer-msg{display:flex;height:100dvh;align-items:center;justify-content:center;color:#888}.admin{max-width:1100px;margin:0 auto;padding:24px 20px 60px}.admin-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:14px}.admin-head h1{font-size:20px;font-weight:800}.admin-tag{font-size:11px;background:#1a73e8;color:#fff;padding:2px 8px;border-radius:20px;vertical-align:middle;margin-left:6px}.admin-sub{font-size:12px;color:#888;margin-top:4px}.admin-sub em{color:#1a73e8;font-style:normal}.admin-sub strong{color:#d93025}.admin-actions{display:flex;gap:8px;flex-wrap:wrap}.a-btn{padding:8px 13px;border-radius:8px;border:1px solid #ddd;background:#fff;font-size:12px;font-weight:600;cursor:pointer;color:#444;text-decoration:none;display:inline-flex;align-items:center}.a-btn:hover{background:#f5f5f5}.a-btn.primary{background:#1a73e8;color:#fff;border-color:#1a73e8}.a-btn.ghost{color:#888}.a-btn.file{cursor:pointer}.admin-note{font-size:12px;color:#666;background:#f8f9fb;border:1px solid #eee;border-radius:10px;padding:12px 14px;line-height:1.7;margin-bottom:16px}.admin-note code{background:#eef1f6;padding:1px 6px;border-radius:5px;font-size:11px}.admin-add{display:grid;grid-template-columns:90px 130px 1fr 2fr auto;gap:8px;margin-bottom:12px}.admin-add input,.admin-add select,.atr input,.atr select{padding:7px 9px;border:1px solid #ddd;border-radius:7px;font-size:12px;min-width:0}.admin-filter{width:100%;padding:8px 11px;border:1px solid #ddd;border-radius:8px;font-size:13px;margin-bottom:10px}.admin-table{border:1px solid #eee;border-radius:10px;overflow:hidden}.atr{display:grid;grid-template-columns:48px 90px 130px 1fr 2fr 56px;gap:8px;align-items:center;padding:7px 10px;border-bottom:1px solid #f2f2f2}.atr:last-child{border-bottom:none}.ath{background:#fafafa;font-size:11px;font-weight:700;color:#999}.aid{font-size:11px;color:#bbb;text-align:center}.a-del{background:#fff;border:1px solid #f0c5c0;color:#d93025;font-size:11px;font-weight:600;padding:6px 8px;border-radius:6px;cursor:pointer}.a-del:hover{background:#fdecea}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-thumb{background:#e0e0e0;border-radius:10px}@media (max-width:640px){.lnb{width:128px}.admin-add,.atr{grid-template-columns:1fr 1fr}.ath{display:none}.atr{border:1px solid #eee;border-radius:8px;margin-bottom:8px;padding:10px}}
