/* Glemmenrussens knuteliste – V2 */
:root{
  --bg:#ffffff; --fg:#111827; --muted:#6b7280; --card:#ffffff; --border:#e5e7eb;
  --accent:#2563eb; --accent-2:#0ea5e9; --danger:#b00020; --ok:#0a6a2b;
  --shadow:0 8px 30px rgba(0,0,0,.06); --radius:16px; --maxw:1100px;
}
:root[data-theme="dark"]{
  --bg:#0b1220; --fg:#e5e7eb; --muted:#9ca3af; --card:#0f172a; --border:#223047;
  --accent:#60a5fa; --accent-2:#22d3ee; --shadow:0 8px 30px rgba(0,0,0,.35);
}
@media (prefers-color-scheme: dark){
  :root:not([data-theme]){
    --bg:#0b1220; --fg:#e5e7eb; --muted:#9ca3af; --card:#0f172a; --border:#223047;
    --accent:#60a5fa; --accent-2:#22d3ee; --shadow:0 8px 30px rgba(0,0,0,.35);
  }
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--fg);line-height:1.45}
a{color:var(--accent);text-decoration:none} a:hover{text-decoration:underline}
.container{max-width:var(--maxw);margin:0 auto;padding:20px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.grid{display:grid;gap:16px} @media (min-width:900px){.grid-2{grid-template-columns:1fr 1fr}}
header.site{position:sticky;top:0;z-index:20;background:color-mix(in oklab,var(--bg) 92%,transparent);backdrop-filter:blur(8px);border-bottom:1px solid var(--border)}
.brand{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 20px;max-width:var(--maxw);margin:0 auto}
.brand-title{display:flex;flex-direction:column;gap:2px}
.brand-title h1{font-size:18px;margin:0} .brand-title p{margin:0;color:var(--muted);font-size:13px}
.navbar{display:flex;align-items:center;gap:10px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:transparent;color:var(--fg);cursor:pointer;font-weight:600}
.btn.primary{background:var(--accent);border-color:color-mix(in oklab,var(--accent) 70%,var(--border));color:white}
.btn.danger{border-color:color-mix(in oklab,var(--danger) 35%,var(--border));color:var(--danger)}
.btn:active{transform:translateY(1px)}
.badge{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--border);border-radius:999px;padding:4px 10px;color:var(--muted);font-size:12px}
.menu-btn{display:inline-flex} @media (min-width:900px){.menu-btn{display:none}}
nav.menu{display:none;max-width:var(--maxw);margin:0 auto;padding:0 20px 14px}
nav.menu.open{display:block}
nav.menu a{display:block;padding:10px 12px;border-radius:12px;border:1px solid var(--border);margin-top:10px}
@media (min-width:900px){
  nav.menu{display:block;padding:0;margin:0}
  nav.menu a{display:inline-block;margin:0 10px 0 0;border:0;padding:8px 6px}
  nav.menu a:hover{background:color-mix(in oklab,var(--accent) 10%,transparent);text-decoration:none}
}
h2{margin:0 0 10px} .muted{color:var(--muted)} .sep{height:1px;background:var(--border);margin:14px 0}
input,textarea,select{width:100%;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:transparent;color:var(--fg)}
label{font-weight:700;font-size:13px} .row{display:grid;gap:8px;margin:12px 0}
.table{width:100%;border-collapse:collapse} .table th,.table td{border-bottom:1px solid var(--border);padding:10px;text-align:left;vertical-align:top}
.table-wrap{overflow:auto}
.knot{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.knot h3{margin:0 0 6px;font-size:16px} .knot p{margin:0;color:var(--muted)}
.knot-actions{min-width:120px;display:flex;justify-content:flex-end}
.alert{padding:10px 12px;border-radius:12px;border:1px solid var(--border);margin:12px 0}
.alert.err{border-color:color-mix(in oklab,var(--danger) 35%,var(--border));color:var(--danger)}
.alert.ok{border-color:color-mix(in oklab,var(--ok) 35%,var(--border));color:var(--ok)}
.footer{padding:22px 0;color:var(--muted);font-size:13px}
.avatar{width:120px;height:120px;border-radius:24px;border:1px solid var(--border);overflow:hidden;position:relative;background:color-mix(in oklab,var(--border) 40%,transparent)}
.avatar img{width:100%;height:100%;object-fit:cover;display:block}
.avatar .badge-img{position:absolute;right:-6px;bottom:-6px;width:54px;height:54px;filter:drop-shadow(0 6px 10px rgba(0,0,0,.25))}
.progress{height:10px;border-radius:999px;border:1px solid var(--border);background:color-mix(in oklab,var(--border) 30%,transparent);overflow:hidden}
.progress>div{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-2))}
