:root{--bg:#0f1115;--card:#1a1d24;--line:#2a2e37;--text:#e8eaed;
  --sub:#9aa0a6;--accent:#ff3b3b;--accent2:#3b82f6;--gold:#ffb020;}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);
  font-family:"맑은 고딕","Malgun Gothic",system-ui,sans-serif;}
header{padding:16px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--bg);z-index:5}
h1{margin:0;font-size:20px}
.sub{color:var(--sub);font-size:13px;margin-top:4px}
.wrap{max-width:1150px;margin:0 auto;padding:16px}
.keybar{display:flex;gap:8px;align-items:center;margin-bottom:10px;background:var(--card);
  padding:10px 12px;border-radius:10px;border:1px solid var(--line);flex-wrap:wrap}
.keybar input{flex:1;min-width:200px;background:#0f1115;border:1px solid var(--line);
  color:var(--text);padding:8px 12px;border-radius:8px;font-size:13px}
.keylabel{font-size:13px;color:var(--sub);min-width:78px}
.tabs{display:flex;gap:8px;margin:14px 0;flex-wrap:wrap}
.tab{padding:9px 16px;border-radius:8px;background:var(--card);border:1px solid var(--line);
  color:var(--sub);cursor:pointer;font-size:14px;font-weight:600}
.tab.on{background:var(--accent2);color:#fff;border-color:var(--accent2)}
.folderbar{display:flex;gap:8px;align-items:center;background:#171a20;border:1px solid var(--line);
  border-radius:10px;padding:8px 12px;margin-bottom:14px;flex-wrap:wrap}
.folderbar .lbl{font-size:13px;color:var(--gold);font-weight:700}
.controls{display:flex;gap:10px;flex-wrap:wrap;align-items:end;margin-bottom:14px}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:12px;color:var(--sub)}
select,.controls input[type=text],.folderbar select{background:var(--card);border:1px solid var(--line);
  color:var(--text);padding:9px 12px;border-radius:8px;font-size:14px}
.controls select,.controls input[type=text]{min-width:130px}
.chk{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--sub);padding-bottom:9px}
button{cursor:pointer;border:none;border-radius:8px;padding:10px 16px;font-size:14px;
  font-weight:700;color:#fff;background:var(--accent)}
button.ghost{background:var(--card);border:1px solid var(--line);color:var(--text);font-weight:500}
button.ai{background:linear-gradient(135deg,#8b5cf6,#3b82f6)}
button.green{background:#1a7f4b}
button.sm{padding:7px 12px;font-size:13px}
button:disabled{opacity:.5;cursor:default}
.status{color:var(--sub);font-size:13px;margin:8px 0 16px;min-height:18px}
.status.err{color:#ff7b7b}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.card{background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden;
  display:flex;flex-direction:column;transition:transform .1s,border-color .1s}
.card:hover{transform:translateY(-3px);border-color:var(--accent2)}
.thumb{position:relative;aspect-ratio:16/9;background:#000;overflow:hidden;display:block}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.dur{position:absolute;right:6px;bottom:6px;background:rgba(0,0,0,.8);font-size:11px;
  padding:2px 6px;border-radius:4px;color:#fff}
.rank{position:absolute;left:6px;top:6px;background:var(--accent);font-size:12px;
  font-weight:700;padding:2px 8px;border-radius:4px;color:#fff}
.boom{position:absolute;right:6px;top:6px;background:var(--gold);color:#000;font-size:12px;
  font-weight:800;padding:2px 8px;border-radius:4px}
.body{padding:10px 12px 12px;display:flex;flex-direction:column;gap:6px;flex:1}
.title{font-size:14px;font-weight:600;line-height:1.35;margin:0;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.meta{font-size:12px;color:var(--sub);line-height:1.55}
.views{color:var(--accent);font-weight:700}
.cardbtns{display:flex;gap:6px;margin-top:auto;padding-top:6px}
.cardbtns button{padding:7px 0;font-size:13px;font-weight:600;flex:1}
.cardbtns .fav{flex:0 0 42px;font-size:15px}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.7);display:none;
  align-items:center;justify-content:center;z-index:20;padding:16px}
.modal.on{display:flex}
.modalbox{background:var(--card);border:1px solid var(--line);border-radius:14px;
  max-width:700px;width:100%;max-height:85vh;display:flex;flex-direction:column}
.modalhead{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;
  justify-content:space-between;align-items:center}
.modalhead b{font-size:16px}
.modalbody{padding:18px;overflow:auto;white-space:pre-wrap;line-height:1.7;font-size:14px}
.xbtn{background:none;color:var(--sub);padding:4px 10px;font-size:20px}
footer{max-width:1150px;margin:36px auto 24px;padding:16px;color:#9aa0a6;font-size:12px;line-height:1.8;border-top:1px solid #2a2e37}
footer a{color:#98a2b3;text-decoration:none;margin-right:14px}
