:root{
  --bg-0:#07090d; --bg-1:#0c1117; --bg-2:#11161f; --bg-3:#171d28;
  --line:rgba(255,255,255,.07); --line-2:rgba(255,255,255,.14);
  --text:#e7ecf3; --text-dim:#94a0b3; --text-mute:#5b6678;
  --accent:#4ade80; --accent-2:#22d3ee; --lime:#a3e635; --danger:#f87171; --warn:#fbbf24;
  --grad:linear-gradient(135deg,#4ade80 0%,#22d3ee 50%,#a3e635 100%);
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;background:var(--bg-0);color:var(--text);
  font-family:'Inter',system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
body{background:
  radial-gradient(1200px 700px at 85% -10%, rgba(74,222,128,.10), transparent 60%),
  radial-gradient(900px 500px at -10% 10%, rgba(34,211,238,.08), transparent 60%),
  radial-gradient(900px 700px at 50% 120%, rgba(163,230,53,.07), transparent 60%),
  var(--bg-0);min-height:100vh;}
a{color:var(--accent-2);text-decoration:none;}
a:hover{text-decoration:underline;}
.container{max-width:1160px;margin:0 auto;padding:0 24px;}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace;}

/* ── Topbar ── */
.topbar{position:sticky;top:0;z-index:30;backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  background:rgba(7,9,13,.65);border-bottom:1px solid var(--line);}
.topbar-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 24px;max-width:1160px;margin:0 auto;}
.brand{display:flex;align-items:center;gap:11px;font-weight:800;letter-spacing:-.01em;font-size:16px;color:var(--text);}
.brand .mark{width:26px;height:26px;border-radius:8px;background:var(--grad);display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 18px rgba(74,222,128,.28);flex:0 0 auto;}
.brand .mark svg{width:15px;height:15px;}
.brand .grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;}
.brand .muted{color:var(--text-dim);font-weight:500;}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:10px;
  border:1px solid var(--line-2);background:rgba(255,255,255,.02);color:var(--text);font-size:13px;
  font-weight:500;cursor:pointer;transition:all .18s ease;font-family:inherit;text-decoration:none;white-space:nowrap;}
.btn:hover{background:var(--bg-3);border-color:rgba(255,255,255,.25);transform:translateY(-1px);text-decoration:none;}
.btn:active{transform:translateY(0);}
.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;}
.btn-primary{background:var(--grad);color:#07090d;border:none;font-weight:700;box-shadow:0 8px 22px rgba(74,222,128,.22);}
.btn-primary:hover{background:var(--grad);filter:brightness(1.08);box-shadow:0 12px 28px rgba(74,222,128,.32);}
.btn-danger{border-color:rgba(248,113,113,.4);color:#fca5a5;background:transparent;}
.btn-danger:hover{background:rgba(248,113,113,.12);border-color:rgba(248,113,113,.6);}
.btn-sm{padding:7px 11px;font-size:12px;border-radius:8px;}
.btn .ico{width:15px;height:15px;display:inline-flex;flex:0 0 auto;}

/* ── Cards (gradient-glow border, как в отчёте) ── */
.card{position:relative;background:linear-gradient(180deg,var(--bg-2),var(--bg-1));
  border:1px solid var(--line);border-radius:18px;padding:20px;overflow:hidden;}
.card::before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;pointer-events:none;
  background:linear-gradient(140deg,var(--glow,rgba(255,255,255,.14)),transparent 55%);opacity:.5;
  -webkit-mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);
  -webkit-mask-composite:xor;mask-composite:exclude;}

/* ── Forms ── */
label{display:block;font-size:12px;color:var(--text-dim);margin:0 0 6px;letter-spacing:.02em;}
input,textarea,select{width:100%;background:var(--bg-0);border:1px solid var(--line-2);border-radius:9px;
  color:var(--text);font-family:inherit;font-size:14px;padding:10px 12px;outline:none;
  transition:border-color .15s,box-shadow .15s;}
input:focus,textarea:focus,select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(74,222,128,.14);}
input[type=color]{padding:4px;height:40px;cursor:pointer;}
textarea{resize:vertical;min-height:74px;font-family:'JetBrains Mono',ui-monospace,monospace;font-size:12.5px;line-height:1.55;}
.field{margin-bottom:14px;}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.hint{font-size:11.5px;color:var(--text-mute);margin-top:4px;}

/* ── Badges / chips ── */
.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.03em;}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;}
.badge.published{background:rgba(74,222,128,.13);color:var(--accent);}
.badge.draft{background:rgba(251,191,36,.13);color:var(--warn);}
.chip{display:block;padding:10px 12px;border-radius:11px;
  background:var(--bg-2);border:1px solid var(--line);min-width:0;overflow:hidden;}
.chip .v{display:block;font-family:'JetBrains Mono',monospace;font-size:14px;font-weight:700;letter-spacing:-.02em;
  color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.3;margin-bottom:3px;}
.chip .v.accent{color:var(--accent);}
.chip .l{display:block;font-size:10px;letter-spacing:.05em;text-transform:uppercase;color:var(--text-mute);
  line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}

/* ── Toast ── */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(8px);background:var(--bg-3);
  border:1px solid var(--line-2);color:var(--text);padding:12px 20px;border-radius:11px;
  box-shadow:0 16px 40px rgba(0,0,0,.5);opacity:0;transition:opacity .22s,transform .22s;z-index:60;pointer-events:none;font-size:13.5px;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.toast.err{border-color:rgba(248,113,113,.5);color:#fca5a5;}

/* ── Misc ── */
.spinner{width:22px;height:22px;border-radius:50%;border:2.5px solid var(--line-2);border-top-color:var(--accent);animation:spin .8s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.fade-in{animation:fadeIn .4s ease both;}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:none;}}
