:root{
  --bg:#fff;
  --surface:#f7f8fb;
  --text:#0b1220;
  --muted:#556370;
  --accent:#ff5252;
  --card:#ffffff;
  --radius:12px;
  --glass: rgba(255,255,255,0.6);
  --shadow: 0 8px 28px rgba(11,18,32,0.06);
}

[data-theme="dark"]{
  --bg:#07101a;
  --surface:#0b1720;
  --text:#e6eef7;
  --muted:#9fb0c2;
  --accent:#ff7b7b;
  --card:#071623;
  --glass: rgba(255,255,255,0.03);
  --shadow: 0 10px 30px rgba(0,0,0,0.6);
}

*{box-sizing:border-box}
html,body{height:100%;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial;color:var(--text);background:linear-gradient(180deg,var(--bg),var(--surface));-webkit-font-smoothing:antialiased}
.visually-hidden{position:absolute!important;height:1px;width:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}

/* Topbar */
.topbar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;max-width:1100px;margin:12px auto;gap:12px}
.brand h1{margin:0;font-size:18px;letter-spacing:0.2px}
.brand .tag{font-size:12px;color:var(--muted)}
.controls{display:flex;align-items:center;gap:8px}
.icon-btn{background:transparent;border:0;padding:8px;border-radius:8px;cursor:pointer;font-size:16px}
.icon-btn:focus{outline:3px solid rgba(255,82,82,0.12);outline-offset:3px;border-radius:8px}

/* Main wrap */
.wrap{max-width:1100px;margin:0 auto;padding:12px}

/* Search bar */
.searchbar{display:flex;gap:8px;align-items:center;margin-bottom:12px}
.searchbar input[type=search]{flex:1;padding:10px 12px;border-radius:10px;border:1px solid rgba(11,18,32,0.06);background:var(--card);font-size:15px}
.searchbar .small{background:transparent;border:0;padding:8px;border-radius:8px;cursor:pointer}
.primary{background:var(--accent);color:white;padding:10px 14px;border-radius:10px;border:0;cursor:pointer}

/* Toolbar */
.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.status{color:var(--muted);font-size:13px}
.toolbar-right{margin-left:auto;display:flex;gap:8px}

/* Results grid */
.results{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.card{background:var(--card);border-radius:12px;padding:10px;display:flex;gap:10px;align-items:flex-start;box-shadow:var(--shadow);transition:transform .12s ease}
.card:hover{transform:translateY(-6px)}
.thumb{width:160px;height:90px;border-radius:10px;overflow:hidden;flex:0 0 160px;background:linear-gradient(180deg,#e6eef7,#cfdbea);display:flex;align-items:center;justify-content:center;cursor:pointer}
.thumb img{width:100%;height:100%;object-fit:cover;display:block}
.info{flex:1;display:flex;flex-direction:column;gap:8px}
.title{font-size:14px;font-weight:700;line-height:1.2;cursor:pointer;color:var(--text);text-decoration:none}
.meta{font-size:13px;color:var(--muted)}
.actions{display:flex;gap:8px;align-items:center;margin-top:auto}
.btn{padding:6px 8px;border-radius:8px;border:1px solid rgba(0,0,0,0.06);background:transparent;cursor:pointer;font-size:13px}
.fav{background:linear-gradient(90deg,rgba(255,82,82,0.12),rgba(255,82,82,0.08));border:0}

/* loading more */
.loading-more{display:none;align-items:center;gap:10px;justify-content:center;padding:18px;color:var(--muted)}
.spinner{width:28px;height:28px;border-radius:50%;border:3px solid rgba(0,0,0,0.08);border-top-color:var(--accent);animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* Modal */
.modal{display:none;position:fixed;inset:0;background:rgba(2,6,12,0.6);backdrop-filter:blur(4px);align-items:center;justify-content:center;padding:18px;z-index:60}
.modal-box{width:100%;max-width:980px;background:var(--card);border-radius:14px;padding:12px;position:relative;box-shadow:var(--shadow)}
.modal-close{position:absolute;right:12px;top:10px;border:0;background:transparent;font-size:20px;cursor:pointer}
.player-wrap{position:relative;padding-top:56.25%;height:0;border-radius:10px;overflow:hidden;background:#000}
.player{position:absolute;inset:0;width:100%;height:100%}
.video-meta{margin-top:10px;color:var(--muted);font-size:13px}

/* Footer */
.foot{max-width:1100px;margin:24px auto;padding:12px;color:var(--muted);text-align:center}

/* Responsive */
@media (max-width:720px){
  .thumb{width:120px;height:72px;flex:0 0 120px}
  .results{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
  .modal-box{padding:8px}
}

/* small helpers */
.small{font-size:13px;padding:8px 10px;border-radius:8px}
.small-muted{color:var(--muted);font-size:13px;margin-top:6px}
