:root{--bg:#0f172a;--card:#111827;--muted:#94a3b8;--accent:#f59e0b;--accent2:#10b981;--text:#e5e7eb}
*{box-sizing:border-box}body{margin:0;background:linear-gradient(180deg,#0b1325,#0f172a);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Arial}
.container{max-width:1100px;margin:0 auto;padding:16px}
.topbar{background:#0b1222;border-bottom:1px solid #1f2937;position:sticky;top:0;z-index:10}
.nav{display:flex;gap:16px;align-items:center;justify-content:space-between}
.brand{font-weight:800;color:#fff;text-decoration:none;font-size:20px}
nav a{color:#cbd5e1;text-decoration:none;margin:0 10px}
nav a:hover{color:#fff}
.btn{background:var(--accent);color:#111827;padding:6px 12px;border-radius:8px;text-decoration:none;font-weight:700}
.card{background:rgba(17,24,39,.7);border:1px solid #1f2937;border-radius:14px;padding:16px;margin:12px 0}
.grid{display:grid;gap:16px}
.grid.cols-2{grid-template-columns:1fr 1fr}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
input,select,textarea{background:#0b1323;border:1px solid #1f2937;color:#e5e7eb;border-radius:10px;padding:10px;width:100%}
label{display:block;margin:6px 0 4px;color:#cbd5e1}
.flash{padding:10px;border-radius:10px;margin:10px 0}
.flash.error{background:#7f1d1d}
.flash.success{background:#064e3b}
.actions{display:flex;gap:10px;align-items:center}
.price{font-weight:800}
.footer{margin-top:40px;border-top:1px solid #1f2937;padding:20px 0;color:#94a3b8}
.table{width:100%;border-collapse:collapse}
.table th,.table td{border-bottom:1px solid #1f2937;padding:8px;text-align:left}
.badge{background:#1f2937;border-radius:999px;padding:4px 8px;color:#e5e7eb;font-size:12px}
.action-btn{background:var(--accent2);padding:8px 12px;border-radius:10px;color:#08231b;text-decoration:none;border:none;cursor:pointer}
.action-btn.secondary{background:var(--accent)}
.del{background:#ef4444;color:white;border:none;padding:6px 10px;border-radius:8px;cursor:pointer}


/* --- Quests Gallery --- */
.page-quests{display:grid;grid-template-columns:1fr 320px;gap:20px}
@media (max-width:1000px){.page-quests{grid-template-columns:1fr}}
.filters{position:sticky;top:74px;background:rgba(17,24,39,.7);border:1px solid #1f2937;border-radius:14px;padding:16px;height:max-content;animation:fadein .4s ease}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
@media (max-width:900px){.gallery{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.gallery{grid-template-columns:1fr}}
.qcard{background:rgba(17,24,39,.7);border:1px solid #1f2937;border-radius:14px;overflow:hidden;transform:translateY(6px);opacity:0;animation:cardIn .5s ease forwards}
.qimg{height:160px;background:#0b1323 url('https://placehold.co/600x360?text=Quest') center/cover no-repeat}
.qbody{padding:12px}
.qtitle{font-weight:700;margin:4px 0}
.qprice{display:flex;gap:10px;align-items:center;color:#e5e7eb}
.qprice img{height:16px;vertical-align:middle}
.qactions{display:flex;gap:10px;margin-top:10px}
.qbtn{background:var(--accent2);border:none;border-radius:10px;padding:8px 12px;color:#08231b;cursor:pointer}
.qbtn.secondary{background:var(--accent);color:#111827}
.qmeta{color:#94a3b8;font-size:13px}

/* Modal */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);display:none;align-items:center;justify-content:center;backdrop-filter:blur(2px);z-index:50}
.modal{width:min(720px,92vw);background:#0b1323;border:1px solid #1f2937;border-radius:16px;transform:scale(.96) translateY(10px);opacity:0}
.modal.open{animation:pop .28s ease forwards}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-bottom:1px solid #1f2937}
.modal-body{padding:16px}
.mclose{background:#111827;border:1px solid #1f2937;border-radius:10px;color:#e5e7eb;padding:6px 10px;cursor:pointer}

/* Animations */
@keyframes fadein{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@keyframes cardIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes pop{from{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}
