:root{
  --bg:#0c1118; --panel:#141c27; --panel2:#1b2533; --line:#26344a; --fg:#e8eef6; --muted:#8aa0bd;
  --accent:#3da9fc; --good:#34d399; --warn:#fbbf24; --bad:#f87171; --radius:12px;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--fg);font:15px/1.5 system-ui,-apple-system,Segoe UI,Roboto,sans-serif}
a{color:var(--accent);text-decoration:none}
.muted{color:var(--muted)}
.err{color:var(--bad);margin-top:8px;min-height:18px}
button{cursor:pointer;border:1px solid var(--line);background:var(--panel2);color:var(--fg);padding:8px 14px;border-radius:8px;font-size:14px}
button:hover{border-color:var(--accent)}
button.primary{background:var(--accent);border-color:var(--accent);color:#04121f;font-weight:600}
button.ghost{background:transparent}
button.danger{border-color:var(--bad);color:var(--bad)}
button.good{border-color:var(--good);color:var(--good)}
input,select,textarea{width:100%;background:#0e151f;border:1px solid var(--line);color:var(--fg);padding:9px 11px;border-radius:8px;font-size:14px;margin:6px 0}
label{font-size:13px;color:var(--muted)}

/* login */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh}
.login-card{background:var(--panel);border:1px solid var(--line);padding:32px;border-radius:var(--radius);width:340px;max-width:92vw}
.login-card h1{margin:0 0 4px;font-size:22px}
.login-card button{width:100%;margin-top:10px}

/* shell */
.topbar{display:flex;align-items:center;gap:14px;padding:10px 16px;background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5;flex-wrap:wrap}
.brand{font-weight:700}
.topbar nav{display:flex;gap:4px;flex-wrap:wrap}
.topbar nav button{background:transparent;border-color:transparent;padding:6px 10px}
.topbar nav button.active{background:var(--panel2);border-color:var(--line)}
.spacer{flex:1}
main{padding:18px;max-width:1200px;margin:0 auto}
.loading{color:var(--muted);padding:40px;text-align:center}
h2{margin:4px 0 14px}

/* cards/grid */
.grid{display:grid;gap:14px}
.cards{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.stat-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px}
.stat .n{font-size:28px;font-weight:700}
.stat .l{color:var(--muted);font-size:13px;text-transform:capitalize}

.item{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column}
.item .media{background:#000;aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;overflow:hidden}
.item .media img,.item .media video{width:100%;height:100%;object-fit:contain}
.item .body{padding:12px;display:flex;flex-direction:column;gap:8px;flex:1}
.item .cap{font-size:13px;max-height:72px;overflow:auto;white-space:pre-wrap}
.row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.tag{font-size:11px;padding:2px 8px;border-radius:99px;border:1px solid var(--line);color:var(--muted)}
.tag.brand{color:var(--accent);border-color:var(--accent)}
.st{font-size:11px;padding:2px 8px;border-radius:99px;font-weight:600}
.st.idea{background:#22303f;color:#9fb3c8}
.st.needs_review{background:#3a2f12;color:#fbbf24}
.st.approved{background:#10362a;color:#34d399}
.st.scheduled{background:#0d2f47;color:#3da9fc}
.st.posted{background:#16321f;color:#7be3a3}
.st.rejected{background:#3a1717;color:#f87171}
.toolbar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px;align-items:center}
.toolbar select{width:auto}
.actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:auto}
.actions button{padding:6px 10px;font-size:13px}

/* modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:20}
.modal.hidden{display:none}
.modal-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:20px;width:480px;max-width:94vw;max-height:90vh;overflow:auto}
table{width:100%;border-collapse:collapse}
th,td{text-align:left;padding:8px;border-bottom:1px solid var(--line);font-size:14px}
.cal-day{margin-bottom:14px}
.cal-day h4{margin:0 0 6px;color:var(--accent)}
@media(max-width:600px){ .topbar{gap:8px} main{padding:12px} }
