
:root{
  --bg:#0e1320;
  --panel:#161b2a;
  --panel-2:#1d2335;
  --text:#e7ebf6;
  --muted:#a7b0c2;
  --brand:#8b5cf6;
  --brand-2:#a78bfa;
  --ok:#10b981;
  --warn:#f59e0b;
  --danger:#ef4444;
  --border:rgba(255,255,255,.08);
  --shadow:0 10px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;font-family:ui-sans-serif,system-ui,Segoe UI,Roboto,Helvetica,Arial;color:var(--text);
  background:radial-gradient(1200px 600px at 70% -20%, rgba(139,92,246,.15), transparent), var(--bg);}
.container{max-width:1060px;margin:0 auto;padding:28px}
.header{position:sticky;top:0;z-index:50;background:linear-gradient(180deg, rgba(14,19,32,.96), rgba(14,19,32,.86) 70%, transparent);backdrop-filter: blur(6px);border-bottom:1px solid var(--border)}
.nav{display:flex;gap:20px;align-items:center;justify-content:space-between;padding:14px 28px}
.links{display:flex;gap:18px}
.nav a{color:var(--muted);text-decoration:none}
.nav a:hover{color:var(--text)}
.brand{display:flex;gap:10px;align-items:center;font-weight:700}
.brand-dot{width:10px;height:10px;border-radius:999px;background:var(--brand)}
.h1{font-size:28px;margin:18px 0 8px}
.sub{color:var(--muted);margin-bottom:28px}
.panel{background:var(--panel);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow)}
.row{display:flex;gap:14px;flex-wrap:wrap}
.control{flex:1;min-width:220px}
label{display:block;color:var(--muted);font-size:12px;margin-bottom:6px}
select,input[type="number"],input[type="text"],button{width:100%;background:var(--panel-2);color:var(--text);border:1px solid var(--border);border-radius:12px;padding:10px 12px;outline:none}
input[type="range"]{width:100%}
.btn{display:inline-flex;align-items:center;justify-content:center;min-height:42px;line-height:1;font-weight:600;cursor:pointer;transition:.15s ease;box-shadow:var(--shadow)}
.btn.brand{background:var(--brand);border-color:transparent}
.btn.brand:hover{background:var(--brand-2)}
.btn.ghost{background:transparent}
.btn:active{transform:translateY(1px) scale(.98); filter:brightness(.96)}
.btn.brand:active{filter:brightness(.95)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;margin-top:18px}
.card{background:var(--panel);border:1px solid var(--border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow)}
.card .thumb{display:flex;align-items:center;justify-content:center;background:#0b1020;height:220px}
.card .thumb canvas,.card .thumb img{max-width:100%;max-height:100%;object-fit:contain}
.card .meta{padding:12px;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.badge{font-size:11px;padding:4px 8px;border-radius:999px;border:1px solid var(--border);color:var(--muted)}
.badge.ok{color:#10b981;border-color:#10b98133;background:#10b98112}
.badge.pending{color:#f59e0b;border-color:#f59e0b44;background:#f59e0b12}
.badge.err{color:#ef4444;border-color:#ef444433;background:#ef444412}
.meta .spacer{flex:1}
.small{font-size:12px;color:var(--muted)}
.footer{padding:40px;text-align:center;color:var(--muted)}
.adbox{margin:14px 0;background:linear-gradient(180deg,#0b1020,#0c1222);border:1px dashed var(--border);border-radius:12px;padding:18px;text-align:center;color:var(--muted)}
.preset-row{display:flex;gap:14px;align-items:flex-end;flex-wrap:wrap}
.preset-row .control{min-width:180px}
/* Pages/Blog */
.page{max-width:840px;margin:0 auto;padding:28px}
.page h1{font-size:30px;margin:8px 0 14px}
.page a{color:var(--brand)}
.searchbar{display:flex;gap:10px;margin:18px 0}
.tags{display:flex;gap:8px;flex-wrap:wrap}
.tag{padding:6px 10px;border:1px solid var(--border);border-radius:999px;color:var(--muted);cursor:pointer}
.tag.active{background:var(--brand);color:#fff;border-color:transparent}
.post{border:1px solid var(--border);border-radius:12px;padding:14px;background:var(--panel);margin:10px 0}
#installPrompt{display:none;position:fixed;right:16px;bottom:16px;background:var(--panel);border:1px solid var(--border);padding:14px 16px;border-radius:12px;box-shadow:var(--shadow)}
#installPrompt button{margin-left:10px}


/* --- Blog header layout: put search below tags (own row) --- */
.blog .searchbar{flex:1 0 100%; width:100%; margin-top:16px;}
.blog .tags{gap:10px; flex-wrap:wrap;}

