:root{--bg:#0f1419;--card:#1a2028;--border:#2a3440;--text:#e6edf3;--muted:#8b949e;--accent:#4a90e2;--accent-hover:#5aa0f2;--error:#f85149}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;min-height:100vh}.wrap{max-width:880px;margin:0 auto;padding:3rem 1.5rem}h1{font-size:1.75rem;margin:0 0 .25rem}.sub{color:var(--muted);margin:0 0 2rem}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:1rem;gap:1rem}.card{display:block;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:1.25rem;text-decoration:none;color:inherit;transition:border-color .15s,transform .15s}.card:hover{border-color:var(--accent);transform:translateY(-1px)}.card h2{font-size:1.1rem;margin:0 0 .5rem}.card p{color:var(--muted);margin:0;font-size:.9rem}.login{max-width:360px;margin:6rem auto;padding:2rem;background:var(--card);border:1px solid var(--border);border-radius:8px}.login h1{font-size:1.25rem;margin-bottom:1.5rem}.login input[type=password]{width:100%;padding:.6rem .75rem;background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:1rem}.login input[type=password]:focus{outline:none;border-color:var(--accent)}.login button{width:100%;margin-top:1rem;padding:.6rem;background:var(--accent);border:none;border-radius:6px;color:white;font-size:1rem;font-weight:500;cursor:pointer}.login button:hover{background:var(--accent-hover)}.err{color:var(--error);font-size:.875rem;margin-top:.75rem}.logout{float:right;background:none;border:1px solid var(--border);color:var(--muted);padding:.35rem .75rem;border-radius:6px;font-size:.85rem;cursor:pointer}.logout:hover{color:var(--text);border-color:var(--accent)}