/* Østfoldrussens knuteliste – modernisert design */
:root{
  color-scheme: light;
  --bg:#f7f8fb;
  --fg:#101827;
  --muted:#667085;
  --card:#ffffff;
  --card-soft:#f4f6f9;
  --border:#dfe4ec;
  --accent:#d71920;
  --accent-2:#00509f;
  --accent-3:#f6b04d;
  --danger:#b42318;
  --ok:#087443;
  --shadow:0 14px 40px rgba(16,24,39,.08);
  --radius:14px;
  --maxw:1120px;
}
:root[data-theme="dark"]{
  color-scheme: dark;
  --bg:#10131a;
  --fg:#f3f6fb;
  --muted:#a7b0bf;
  --card:#171c26;
  --card-soft:#111722;
  --border:#2c3544;
  --accent:#ff4d55;
  --accent-2:#63a8ff;
  --accent-3:#f8bd61;
  --danger:#ff817a;
  --ok:#53d08a;
  --shadow:0 18px 48px rgba(0,0,0,.32);
}
@media (prefers-color-scheme: dark){
  :root:not([data-theme]){
    color-scheme: dark;
    --bg:#10131a;
    --fg:#f3f6fb;
    --muted:#a7b0bf;
    --card:#171c26;
    --card-soft:#111722;
    --border:#2c3544;
    --accent:#ff4d55;
    --accent-2:#63a8ff;
    --accent-3:#f8bd61;
    --shadow:0 18px 48px rgba(0,0,0,.32);
  }
}
*{box-sizing:border-box}
html{min-height:100%}
body{
  margin:0;
  min-height:100%;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  background:
    radial-gradient(circle at 8% 0%, color-mix(in oklab,var(--accent) 12%,transparent) 0, transparent 28rem),
    radial-gradient(circle at 95% 12%, color-mix(in oklab,var(--accent-2) 12%,transparent) 0, transparent 30rem),
    linear-gradient(180deg, color-mix(in oklab,var(--card) 55%,var(--bg)), var(--bg) 28rem);
  color:var(--fg);
  line-height:1.5;
}
a{color:var(--accent-2);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--maxw);margin:0 auto;padding:22px 18px 28px}
.grid{display:grid;gap:16px}
@media (min-width:900px){.grid-2{grid-template-columns:1fr 1fr}}
.card{
  background:color-mix(in oklab,var(--card) 96%,transparent);
  border:1px solid color-mix(in oklab,var(--border) 88%,transparent);
  border-radius:var(--radius);
  padding:18px;
  box-shadow:var(--shadow);
}
header.site{
  position:sticky;
  top:0;
  z-index:20;
  border-bottom:1px solid color-mix(in oklab,var(--border) 75%,transparent);
  background:color-mix(in oklab,var(--card) 88%,transparent);
  backdrop-filter:blur(14px);
}
.brand{
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center;
  gap:14px;
  max-width:var(--maxw);
  margin:0 auto;
  padding:12px 18px;
}
.brand-mark{
  width:66px;
  height:54px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:visible;
  background:transparent;
  border:0;
  box-shadow:none;
}
.brand-mark img{width:66px;height:54px;object-fit:contain;display:block}
.brand-title{min-width:0}
.brand-title h1{font-size:20px;line-height:1.1;margin:0;font-weight:900}
.brand-title p{margin:4px 0 0;color:var(--muted);font-size:13px}
.navbar{display:flex;align-items:center;gap:8px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:40px;
  padding:9px 13px;
  border-radius:10px;
  border:1px solid var(--border);
  background:color-mix(in oklab,var(--card) 92%,transparent);
  color:var(--fg);
  cursor:pointer;
  font-weight:750;
  transition:transform .12s ease, border-color .12s ease, background .12s ease;
}
.btn:hover{border-color:color-mix(in oklab,var(--accent-2) 45%,var(--border));text-decoration:none}
.btn.primary{background:linear-gradient(135deg,var(--accent),#ef4444);border-color:transparent;color:white}
.btn.danger{border-color:color-mix(in oklab,var(--danger) 45%,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:5px 10px;
  background:var(--card-soft);
  color:var(--muted);
  font-size:12px;
  font-weight:750;
}
.menu-btn{display:inline-flex}
nav.menu{display:none;max-width:var(--maxw);margin:0 auto;padding:0 18px 14px}
nav.menu.open{display:block}
nav.menu a{
  display:block;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid var(--border);
  margin-top:8px;
  color:var(--fg);
  font-weight:750;
}
@media (min-width:900px){
  .menu-btn{display:none}
  nav.menu{
    display:flex;
    gap:6px;
    align-items:center;
    padding:0 18px 12px;
  }
  nav.menu a{
    margin:0;
    border:0;
    padding:8px 10px;
    color:var(--muted);
  }
  nav.menu a:hover{
    color:var(--fg);
    background:color-mix(in oklab,var(--accent-2) 10%,transparent);
    text-decoration:none;
  }
}
h2{margin:0 0 10px;font-size:22px;letter-spacing:0}
h3{letter-spacing:0}
.muted{color:var(--muted)}
.sep{height:1px;background:var(--border);margin:14px 0}
input,textarea,select{
  width:100%;
  padding:11px 12px;
  border-radius:10px;
  border:1px solid var(--border);
  background:var(--card);
  color:var(--fg);
  font:inherit;
}
input:focus,textarea:focus,select:focus{
  outline:2px solid color-mix(in oklab,var(--accent-2) 28%,transparent);
  border-color:color-mix(in oklab,var(--accent-2) 55%,var(--border));
}
label{font-weight:800;font-size:13px}
.row{display:grid;gap:8px;margin:12px 0}
.table{width:100%;border-collapse:separate;border-spacing:0}
.table th,.table td{border-bottom:1px solid var(--border);padding:11px 10px;text-align:left;vertical-align:top}
.table th{color:var(--muted);font-size:13px;font-weight:850}
.table tr:hover td{background:color-mix(in oklab,var(--accent-2) 5%,transparent)}
.table-wrap{overflow:auto}
.knot{display:flex;justify-content:space-between;gap:14px;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:11px 12px;border-radius:10px;border:1px solid var(--border);margin:12px 0;background:var(--card-soft)}
.alert.err{border-color:color-mix(in oklab,var(--danger) 38%,var(--border));color:var(--danger)}
.alert.ok{border-color:color-mix(in oklab,var(--ok) 38%,var(--border));color:var(--ok)}
.footer{padding:22px 0;color:var(--muted);font-size:13px}
.avatar{
  width:120px;
  height:120px;
  border-radius:22px;
  border:1px solid var(--border);
  overflow:hidden;
  position:relative;
  background:var(--card-soft);
  box-shadow:0 10px 26px rgba(16,24,39,.08);
}
.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:var(--card-soft);overflow:hidden}
.progress>div{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent-3),var(--accent-2))}
.secret-modal{
  position:fixed;
  inset:0;
  z-index:80;
  display:grid;
  place-items:center;
  padding:18px;
  background:rgba(10,15,25,.72);
  backdrop-filter:blur(8px);
}
.secret-modal[hidden]{display:none}
.secret-panel{
  position:relative;
  width:min(92vw,720px);
  max-height:86vh;
}
.secret-panel img{
  display:block;
  width:100%;
  max-height:86vh;
  object-fit:contain;
  border-radius:14px;
  box-shadow:0 24px 70px rgba(0,0,0,.42);
}
.secret-close{
  position:absolute;
  top:-12px;
  right:-12px;
  width:38px;
  height:38px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.22);
  background:#ffffff;
  color:#101827;
  font-size:26px;
  line-height:1;
  cursor:pointer;
  box-shadow:0 10px 26px rgba(0,0,0,.28);
}
@media (max-width:620px){
  .brand{grid-template-columns:auto 1fr;gap:10px}
  .navbar{grid-column:1 / -1;justify-content:flex-end}
  .brand-title h1{font-size:18px}
  .brand-title p{font-size:12px}
  .brand-mark{width:48px;height:48px}
  .brand-mark img{width:56px;height:48px}
  .container{padding:16px 12px 24px}
  .card{padding:14px}
  .knot{flex-direction:column}
  .knot-actions{min-width:0;width:100%;justify-content:flex-start}
}
