:root{--bg:#f4f2ee;--card:#fff;--ink:#1d2226;--muted:#5e6670;--line:#e3e0db;--accent:#0a66c2;--net:#057642;--warn:#915907;--drop:#b24020}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--ink);font:14px/1.5 -apple-system,"Segoe UI",Roboto,sans-serif}

/* login */
#login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.loginbox{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:28px;width:100%;max-width:340px;display:flex;flex-direction:column;gap:10px}
.loginbox h1{font-size:18px;margin:0}
.loginbox .sub{color:var(--muted);font-size:13px;margin:0 0 8px}
.loginbox input{font:inherit;padding:9px 10px;border:1px solid var(--line);border-radius:8px}
.loginbox button{font:inherit;font-weight:600;background:var(--accent);color:#fff;border:0;border-radius:8px;padding:10px;cursor:pointer}
.loginbox button:disabled{opacity:.6}
.err{color:var(--drop);font-size:12px;min-height:16px}

/* app */
header{position:sticky;top:0;background:var(--card);border-bottom:1px solid var(--line);padding:12px 16px;z-index:5}
h1{font-size:17px;margin:0 0 6px}
.meta{color:var(--muted);font-size:12px}
.row{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:6px;font-size:12px;color:var(--muted)}
.row .spacer{flex:1}
.row .who{font-size:11px}
.filters label{display:inline-flex;gap:4px;align-items:center;margin-right:6px}
.ghost{font:inherit;font-size:12px;background:none;border:1px solid var(--line);border-radius:14px;padding:3px 10px;color:var(--accent);cursor:pointer}
main{max-width:640px;margin:16px auto;padding:0 12px}
.post{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin-bottom:12px}
.ctx{color:var(--muted);font-size:12px;font-style:italic;margin-bottom:6px}
.author{font-weight:600}
.deg{font-size:10px;color:var(--muted);border:1px solid var(--line);border-radius:8px;padding:1px 5px;margin-left:4px}
.body{white-space:pre-wrap}
.linkcard{display:flex;gap:10px;align-items:center;margin-top:10px;border:1px solid var(--line);border-radius:8px;padding:8px;text-decoration:none;color:inherit}
.linkcard img{width:72px;height:72px;object-fit:cover;border-radius:6px;flex:none}
.linkcard .lt{font-weight:600;font-size:13px}
.linkcard .ls{color:var(--muted);font-size:11px;margin-top:2px}
.media{margin-top:10px;border-radius:8px;max-width:100%;max-height:480px;display:block;border:1px solid var(--line)}
.tag{font-size:10px;font-weight:700;padding:2px 7px;border-radius:9px}
.tag.NETWORK{background:#e6f4ec;color:var(--net)}
.tag.ENGAGEMENT,.tag.SUGGESTED{background:#fdf3e3;color:var(--warn)}
.tag.PROMOTED{background:#fbe9e2;color:var(--drop)}
.tag.UNKNOWN{background:#eee;color:var(--muted)}
.seen{color:var(--muted);font-size:11px}
.empty{color:var(--muted);text-align:center;padding:40px}

/* comment composer */
.cmt{margin-top:10px;border-top:1px solid var(--line);padding-top:8px}
.cbtn{font:inherit;font-size:12px;background:none;border:1px solid var(--line);border-radius:16px;padding:4px 12px;color:var(--accent);cursor:pointer}
.cbtn:hover{background:#eef3f8}
.cbox{margin-top:8px}
.cbox textarea{width:100%;min-height:64px;font:inherit;padding:8px;border:1px solid var(--line);border-radius:8px;resize:vertical}
.crow{display:flex;gap:8px;align-items:center;margin-top:6px;flex-wrap:wrap}
.crow button{font:inherit;font-size:12px;border:1px solid var(--line);border-radius:16px;padding:4px 12px;cursor:pointer;background:#fff}
.crow button.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.crow button:disabled{opacity:.5;cursor:default}
.cstatus{font-size:11px;color:var(--muted)}
.cstatus.ok{color:var(--net)}
.cstatus.err{color:var(--drop)}
.nolink{font-size:11px;color:var(--muted);font-style:italic;margin-top:8px;border-top:1px solid var(--line);padding-top:8px}
