:root{
  --bg:#0E1116; --panel:#161B22; --line:#232A33;
  --text:#C9D1D9; --muted:#8B949E; --ember:#FF6A3D;
  --mono:'JetBrains Mono',ui-monospace,monospace;
  --disp:'Space Grotesk',system-ui,sans-serif;
  --body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--body);
  -webkit-font-smoothing:antialiased}
h1,h2,.rail__brand,.login__brand{font-family:var(--disp);font-weight:700}

/* login */
.login{min-height:100vh;display:grid;place-items:center;padding:24px}
.login__card{background:var(--panel);border:1px solid var(--line);border-radius:14px;
  padding:32px;width:min(360px,100%);display:flex;flex-direction:column;gap:12px}
.login__brand{margin:0 0 8px;font-size:24px}
.login__brand span{color:var(--ember)}
.login__label{font-size:13px;color:var(--muted)}
.login__input{background:var(--bg);border:1px solid var(--line);border-radius:8px;
  color:var(--text);padding:10px 12px;font-family:var(--mono)}
.login__input:focus-visible{outline:2px solid var(--ember);outline-offset:1px}
.login__btn{margin-top:8px;background:var(--ember);color:#1a0d07;border:0;border-radius:8px;
  padding:11px;font-weight:600;cursor:pointer;font-family:var(--disp)}
.login__error{color:#FF6A3D;background:rgba(255,106,61,.1);border:1px solid rgba(255,106,61,.3);
  border-radius:8px;padding:8px 10px;margin:0;font-size:14px}

/* shell */
.shell{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.rail{background:var(--panel);border-right:1px solid var(--line);padding:20px 16px;
  display:flex;flex-direction:column;gap:8px}
.rail__brand{font-size:18px;margin-bottom:12px}
.rail__link{color:var(--text);text-decoration:none;padding:8px 10px;border-radius:8px}
.rail__link[aria-current="page"]{background:var(--bg);border:1px solid var(--line)}
.rail__soon{margin-top:auto;color:var(--muted);font-size:12px;line-height:1.5}
.topbar{display:flex;justify-content:space-between;align-items:center;
  padding:14px 24px;border-bottom:1px solid var(--line)}
.topbar__status{color:var(--muted);font-family:var(--mono);font-size:13px}
.topbar__logout{background:transparent;color:var(--text);border:1px solid var(--line);
  border-radius:8px;padding:7px 14px;cursor:pointer}
.content{padding:24px}
.health{list-style:none;padding:0;display:flex;flex-direction:column;gap:6px;font-family:var(--mono)}
.health__item.ok{color:#7EE2B8}
.health__item.bad{color:var(--ember)}

@media (max-width:640px){.shell{grid-template-columns:1fr}.rail{flex-direction:row;flex-wrap:wrap;border-right:0;border-bottom:1px solid var(--line)}}
@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}

/* страница генерации */
.gen{display:grid;grid-template-columns:300px 1fr;gap:20px;align-items:start}
.sitelist{list-style:none;padding:0;display:flex;flex-direction:column;gap:8px}
.sitelist__item{display:flex;justify-content:space-between;align-items:center;gap:10px;
  background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:8px 12px}
.sitelist__name{font-family:var(--mono);font-size:13px}
.btn-run{background:var(--ember);color:#1a0d07;border:0;border-radius:7px;padding:7px 12px;
  font-family:var(--disp);font-weight:600;cursor:pointer}
.btn-run:disabled{opacity:.5;cursor:not-allowed}
.muted{color:var(--muted)}
.steprail{list-style:none;display:flex;flex-wrap:wrap;gap:8px;padding:0;margin:0 0 12px}
.steprail__step{font-family:var(--mono);font-size:12px;color:var(--muted);
  border:1px solid var(--line);border-radius:999px;padding:4px 10px}
.steprail__step.done{color:#7EE2B8;border-color:#27432f}
.steprail__step.active{color:#1a0d07;background:var(--ember);border-color:var(--ember);
  animation:pulse 1.2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.55}}
.log{background:#0a0d12;border:1px solid var(--line);border-radius:10px;padding:14px;
  font-family:var(--mono);font-size:12.5px;line-height:1.5;color:var(--text);
  height:60vh;overflow:auto;white-space:pre-wrap;word-break:break-word;margin:0}
@media (max-width:860px){.gen{grid-template-columns:1fr}}
@media (prefers-reduced-motion:reduce){.steprail__step.active{animation:none}}

/* библиотека */
.upload{display:flex;align-items:center;gap:12px;flex-wrap:wrap;background:var(--panel);
  border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin:0 0 20px}
.upload__label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--muted)}
.upload__input{color:var(--text);font-family:var(--mono);font-size:12px}
.upload__hint{font-size:12px}
.sitelib{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.sitelib__item{display:flex;justify-content:space-between;align-items:center;gap:12px;
  background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:10px 14px}
.sitelib__item--bad{border-color:#5a2d2d}
.sitelib__main{display:flex;flex-direction:column;gap:2px;min-width:0}
.sitelib__actions{display:flex;align-items:center;gap:10px;flex-shrink:0}
.sitelib__id{font-family:var(--disp);font-weight:600}
.sitelib__meta{font-family:var(--mono);font-size:12px;color:var(--muted)}
.btn-del{background:transparent;color:var(--ember);border:1px solid #5a2d2d;border-radius:7px;
  padding:7px 12px;cursor:pointer;font-family:var(--disp)}
.btn-del:hover{background:rgba(255,106,61,.1)}

/* промты */
.prompt{background:var(--panel);border:1px solid var(--line);border-radius:10px;
  padding:16px;margin:0 0 18px}
.prompt__title{font-family:var(--mono);font-size:14px;margin:0 0 10px;color:var(--muted)}
.prompt__text{width:100%;background:#0a0d12;border:1px solid var(--line);border-radius:8px;
  color:var(--text);font-family:var(--mono);font-size:12.5px;line-height:1.5;padding:12px;
  resize:vertical;box-sizing:border-box}
.prompt__text:focus-visible{outline:2px solid var(--ember);outline-offset:1px}
.prompt__bar{display:flex;align-items:center;gap:14px;margin-top:10px;flex-wrap:wrap}
.prompt__hist summary{cursor:pointer;color:var(--muted);font-size:13px}
.histlist{list-style:none;padding:8px 0 0;margin:0;display:flex;flex-direction:column;gap:6px}
.histlist__item{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.histlist__stamp{font-family:var(--mono);font-size:12px;color:var(--muted)}
.btn-link{background:transparent;border:0;color:var(--text);cursor:pointer;
  text-decoration:underline;font-size:12px;padding:2px 4px}

/* настройки + диалог карточки */
.settings{display:flex;flex-direction:column;gap:14px;max-width:680px}
.settings__row{display:flex;flex-direction:column;gap:4px;font-size:13px;color:var(--muted)}
.settings__input{background:var(--bg);border:1px solid var(--line);border-radius:8px;
  color:var(--text);padding:9px 12px;font-family:var(--mono)}
.settings__input:focus-visible{outline:2px solid var(--ember);outline-offset:1px}
.cgdlg{background:var(--panel);color:var(--text);border:1px solid var(--line);border-radius:12px;
  padding:20px;max-width:680px;width:92%}
.cgdlg::backdrop{background:rgba(0,0,0,.6)}
.cgdlg__form{display:flex;flex-direction:column;gap:10px}
.cgdlg__text,.cgdlg__input{background:var(--bg);border:1px solid var(--line);border-radius:8px;
  color:var(--text);padding:9px 12px;font-family:var(--mono)}
.cgdlg__bar{display:flex;gap:12px;align-items:center}

/* превью */
.prevlist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}
.prevlist__item{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap;
  background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:10px 14px}
.prevlist__host{font-family:var(--mono);font-size:13px}
.prevlist__bar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}

/* деплой */
.acc-add,.dep-run{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin:0 0 14px}
.acclist,.dep-sites,.deplist{list-style:none;padding:0;margin:0 0 18px;display:flex;flex-direction:column;gap:8px}
.acclist__item{display:flex;align-items:center;gap:12px;flex-wrap:wrap;
  background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:10px 14px}
.acclist__name{font-family:var(--disp);font-weight:600}
.acclist__tok{font-family:var(--mono);font-size:12px}
.dep-sites__item{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:12px 14px}
.dep-sites__head{display:flex;gap:10px;align-items:baseline;margin-bottom:8px}
.dep-sites__id{font-family:var(--disp);font-weight:600}
.deplist{margin-top:8px}
.deplist__item{font-family:var(--mono);font-size:12px}
a.btn-run{text-decoration:none;display:inline-block}
