/* hh-autoapply — дизайн-система с темами (тёмная по умолчанию + светлая) */

:root, :root[data-theme="dark"]{
  --bg:#0b0e14; --surface:#12161f; --surface-2:#171c28; --elevated:#1b2130;
  --input-bg:#0b0e14; --code-bg:#0b0e14; --code-fg:#c7cede;
  --line:#232a38; --line-2:#2c3546;
  --text:#e7eaf0; --muted:#8b93a7; --faint:#5c6577;
  --accent:#6d7bff; --accent-2:#8b95ff; --accent-ghost:rgba(109,123,255,.14);
  --ok:#37d39a; --ok-bg:rgba(55,211,154,.14);
  --fail:#f2717b; --fail-bg:rgba(242,113,123,.14);
  --warn:#f5b342; --warn-bg:rgba(245,179,66,.14);
  --shadow:0 1px 3px rgba(0,0,0,.4),0 8px 24px rgba(0,0,0,.24);
  --glow:rgba(109,123,255,.10);
}
:root[data-theme="light"]{
  --bg:#f5f7fa; --surface:#ffffff; --surface-2:#f1f4f8; --elevated:#e9edf3;
  --input-bg:#ffffff; --code-bg:#f4f6f9; --code-fg:#2d3340;
  --line:#e4e8ee; --line-2:#d4dae3;
  --text:#1a2030; --muted:#5b6577; --faint:#98a2b3;
  --accent:#5b63f0; --accent-2:#4a52e0; --accent-ghost:rgba(91,99,240,.10);
  --ok:#0f9d63; --ok-bg:rgba(15,157,99,.12);
  --fail:#d64550; --fail-bg:rgba(214,69,80,.10);
  --warn:#b7791f; --warn-bg:rgba(183,121,31,.12);
  --shadow:0 1px 2px rgba(16,24,40,.06),0 8px 24px rgba(16,24,40,.08);
  --glow:rgba(91,99,240,.10);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
:root{--radius:12px;--radius-sm:9px;--sidebar:240px}
body{
  background:radial-gradient(1200px 600px at 80% -10%,var(--glow),transparent 60%),var(--bg);
  color:var(--text);
  font:14px/1.55 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,system-ui,sans-serif;
  -webkit-font-smoothing:antialiased; min-height:100vh;
  transition:background-color .2s,color .2s;
}
a{color:var(--accent-2);text-decoration:none}
a:hover{text-decoration:underline}
h1{font-size:22px;font-weight:650;letter-spacing:-.01em;margin:0 0 2px}
h2{font-size:15px;font-weight:600;color:var(--text);margin:26px 0 12px;display:flex;align-items:center;gap:8px}
h2::before{content:"";width:3px;height:15px;border-radius:2px;background:var(--accent);display:inline-block}
.sub{color:var(--muted);font-size:13px}

/* ---------- layout shell ---------- */
.layout{display:flex;min-height:100vh}
.sidebar{
  width:var(--sidebar);flex:0 0 var(--sidebar);position:sticky;top:0;height:100vh;
  background:linear-gradient(180deg,var(--surface),var(--bg));
  border-right:1px solid var(--line);display:flex;flex-direction:column;padding:18px 14px;
}
.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 18px;font-weight:700;font-size:16px;letter-spacing:-.01em}
.brand .logo{display:inline-flex;flex:0 0 auto;filter:drop-shadow(0 4px 12px var(--accent-ghost))}
.brand .logo svg{width:100%;height:100%;display:block;border-radius:8px}
.brand .wm{white-space:nowrap}
.brand .wm .bdot{color:var(--accent-2)}
.nav{display:flex;flex-direction:column;gap:2px;flex:1}
.nav a{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--radius-sm);
  color:var(--muted);font-weight:500;transition:.12s}
.nav a:hover{background:var(--surface-2);color:var(--text);text-decoration:none}
.nav a.on{background:var(--accent-ghost);color:var(--accent-2)}
.nav a.on svg{color:var(--accent-2)}
.nav a svg{width:18px;height:18px;flex:0 0 18px;color:var(--faint)}
.side-foot{border-top:1px solid var(--line);padding-top:12px;margin-top:8px;font-size:13px}
.side-foot .who{display:flex;align-items:center;gap:9px;padding:6px 8px}
.side-foot .ava{width:28px;height:28px;border-radius:50%;background:var(--elevated);display:grid;place-items:center;
  color:var(--accent-2);font-weight:600;font-size:12px;border:1px solid var(--line-2)}
.side-foot .who .n{font-weight:600;line-height:1.1}
.side-foot .who .r{color:var(--faint);font-size:11px}
.side-foot .frow{display:flex;align-items:center;gap:6px;margin-top:4px}
.side-foot .frow a{flex:1;padding:6px 8px;color:var(--muted);border-radius:var(--radius-sm)}
.side-foot .frow a:hover{background:var(--surface-2);text-decoration:none}

/* theme toggle */
.theme-toggle{width:34px;height:34px;flex:0 0 34px;border-radius:var(--radius-sm);border:1px solid var(--line-2);
  background:var(--surface-2);color:var(--muted);display:grid;place-items:center;cursor:pointer;transition:.12s;padding:0}
.theme-toggle:hover{color:var(--text);border-color:var(--faint);background:var(--elevated);transform:none}
.theme-toggle svg{width:17px;height:17px}
.theme-toggle .moon{display:none}
:root[data-theme="dark"] .theme-toggle .moon{display:block}
:root[data-theme="dark"] .theme-toggle .sun{display:none}

.content{flex:1;min-width:0;padding:26px 34px 60px;max-width:1180px}
.page-head{display:flex;align-items:flex-start;gap:14px;flex-wrap:wrap;margin-bottom:8px}
.page-head .actions{margin-left:auto;display:flex;gap:10px;flex-wrap:wrap}

/* ---------- panels & cards ---------- */
.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:18px 20px;margin:14px 0;box-shadow:var(--shadow)}
.panel h2:first-child{margin-top:0}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}
.card{background:linear-gradient(180deg,var(--surface-2),var(--surface));border:1px solid var(--line);
  border-radius:var(--radius);padding:16px 18px;position:relative;overflow:hidden}
.card::after{content:"";position:absolute;inset:0 auto 0 0;width:3px;background:var(--accent);opacity:.5}
.card .n{font-size:28px;font-weight:700;letter-spacing:-.02em;line-height:1}
.card .t{color:var(--muted);font-size:12px;margin-top:6px;text-transform:uppercase;letter-spacing:.04em}

/* ---------- forms ---------- */
label{display:block;color:var(--muted);font-size:12px;font-weight:500;margin:12px 0 5px;letter-spacing:.01em}
input,select,textarea{width:100%;background:var(--input-bg);color:var(--text);border:1px solid var(--line-2);
  border-radius:var(--radius-sm);padding:9px 12px;font:inherit;transition:.12s}
input::placeholder,textarea::placeholder{color:var(--faint)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ghost)}
textarea{min-height:90px;resize:vertical;font-family:inherit}
.row{display:flex;gap:16px;flex-wrap:wrap}
.row>div{flex:1;min-width:180px}
.checks{display:flex;gap:16px;flex-wrap:wrap;margin-top:6px}
.checks label{display:inline-flex;align-items:center;gap:7px;margin:0;color:var(--text);font-size:14px;cursor:pointer}
.checks input{width:auto}
.field-hint{color:var(--faint);font-size:12px;margin-top:4px}

/* ---------- buttons ---------- */
button,.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;
  background:var(--accent);color:#fff;border:1px solid transparent;border-radius:var(--radius-sm);
  padding:9px 16px;font:inherit;font-weight:600;cursor:pointer;transition:.12s;text-decoration:none}
button:hover,.btn:hover{background:var(--accent-2);text-decoration:none;transform:translateY(-1px)}
button:active,.btn:active{transform:none}
button:disabled{opacity:.45;cursor:not-allowed;transform:none}
button.sec,.btn.sec{background:transparent;color:var(--text);border-color:var(--line-2)}
button.sec:hover,.btn.sec:hover{background:var(--surface-2);border-color:var(--faint)}
button.danger,.btn.danger{background:transparent;color:var(--fail);border-color:var(--fail)}
button.danger:hover{background:var(--fail-bg)}
button.sm,.btn.sm{padding:6px 11px;font-size:12.5px;font-weight:500}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}

/* ---------- tables ---------- */
.table-wrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  overflow:auto;box-shadow:var(--shadow)}
table{border-collapse:collapse;width:100%;font-size:13.5px}
thead th{position:sticky;top:0;background:var(--surface-2);color:var(--muted);font-weight:600;
  text-align:left;padding:11px 14px;border-bottom:1px solid var(--line);white-space:nowrap;font-size:12px;
  text-transform:uppercase;letter-spacing:.03em}
tbody td{padding:11px 14px;border-bottom:1px solid var(--line)}
tbody tr:last-child td{border-bottom:0}
tbody tr{transition:.1s}
tbody tr:hover td{background:var(--surface-2)}
td .actions{display:flex;gap:6px;flex-wrap:wrap}
td form{display:inline}

/* ---------- badges / status ---------- */
.tag{display:inline-flex;align-items:center;gap:5px;padding:2px 10px;border-radius:999px;font-size:11.5px;
  font-weight:600;background:var(--elevated);color:var(--muted);border:1px solid var(--line-2)}
.tag.active,.tag.ok{background:var(--ok-bg);color:var(--ok);border-color:transparent}
.tag.baseline{background:var(--accent-ghost);color:var(--accent-2);border-color:transparent}
.tag.draft{background:var(--elevated);color:var(--muted)}
.tag.retired,.tag.off{background:transparent;color:var(--faint)}
.tag.err,.tag.fail{background:var(--fail-bg);color:var(--fail);border-color:transparent}
.tag.warn{background:var(--warn-bg);color:var(--warn);border-color:transparent}
.ok{color:var(--ok)}.fail{color:var(--fail)}.warn{color:var(--warn)}.muted{color:var(--muted)}

/* ---------- flash ---------- */
.flash{padding:12px 16px;border-radius:var(--radius-sm);margin:0 0 16px;font-weight:500;
  display:flex;align-items:center;gap:10px;border:1px solid transparent}
.flash::before{content:"";width:8px;height:8px;border-radius:50%;flex:0 0 8px}
.flash.ok{background:var(--ok-bg);color:var(--ok)}.flash.ok::before{background:var(--ok)}
.flash.err{background:var(--fail-bg);color:var(--fail)}.flash.err::before{background:var(--fail)}

/* ---------- misc ---------- */
pre.log{white-space:pre-wrap;background:var(--code-bg);border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:14px;margin:0;max-height:62vh;overflow:auto;
  font:12.5px/1.6 ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--code-fg)}
canvas{max-height:290px}
.collapse-row{cursor:pointer;padding:8px 0;border-bottom:1px solid var(--line)}
.collapse-row:hover{color:var(--accent-2)}
.letter-body{display:none;white-space:pre-wrap;background:var(--code-bg);border:1px solid var(--line);
  border-radius:var(--radius-sm);padding:12px;margin:8px 0 12px;color:var(--code-fg)}
.empty{color:var(--faint);text-align:center;padding:26px}

/* ---------- login ---------- */
.auth{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative}
.auth .theme-toggle{position:absolute;top:20px;right:20px}
.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--line);
  border-radius:16px;padding:32px 30px;box-shadow:var(--shadow)}
.auth-card .brand{justify-content:center;padding:0 0 6px;font-size:19px}
.auth-card .sub{text-align:center;margin-bottom:22px}
.auth-card button{width:100%;margin-top:18px;padding:11px}

/* ---------- landing ---------- */
.lp{max-width:1080px;margin:0 auto;padding:0 22px}
.lp-nav{display:flex;align-items:center;gap:14px;padding:18px 0}
.lp-nav .brand{padding:0}
.lp-nav .sp{margin-left:auto;display:flex;gap:10px;align-items:center}
.hero{position:relative;text-align:center;padding:64px 0 40px;overflow:hidden}
.hero::before{content:"";position:absolute;inset:-40% 0 auto 0;height:520px;z-index:-1;
  background:radial-gradient(600px 300px at 50% 0,var(--accent-ghost),transparent 70%)}
.hero .pill{display:inline-flex;align-items:center;gap:7px;padding:5px 14px;border-radius:999px;
  background:var(--accent-ghost);color:var(--accent-2);font-weight:600;font-size:13px;margin-bottom:20px}
.hero h1{font-size:clamp(30px,5vw,52px);line-height:1.06;letter-spacing:-.03em;margin:0 auto;max-width:820px;font-weight:750}
.hero h1 .grad{background:linear-gradient(120deg,var(--accent),#a78bfa,#4c5bd4);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p.lead{font-size:clamp(16px,2vw,20px);color:var(--muted);max-width:600px;margin:20px auto 0}
.hero .cta{display:flex;gap:12px;justify-content:center;margin-top:30px;flex-wrap:wrap}
.hero .cta .btn{padding:12px 24px;font-size:15px}
.hero .btn.big{box-shadow:0 8px 24px var(--accent-ghost)}
.statline{display:flex;gap:34px;justify-content:center;flex-wrap:wrap;margin:38px 0 8px;color:var(--muted)}
.statline b{color:var(--text);font-size:24px;font-weight:750;letter-spacing:-.02em;display:block}
.section{padding:44px 0}
.section h2.center{justify-content:center;font-size:26px;letter-spacing:-.02em;margin-bottom:6px}
.section h2.center::before{display:none}
.section .subc{text-align:center;color:var(--muted);margin-bottom:30px}
.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px}
.feature{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:22px;
  box-shadow:var(--shadow);transition:.15s}
.feature:hover{transform:translateY(-3px);border-color:var(--line-2)}
.feature .ic{width:44px;height:44px;border-radius:11px;display:grid;place-items:center;margin-bottom:14px;
  background:var(--accent-ghost);color:var(--accent-2)}
.feature .ic svg{width:22px;height:22px}
.feature h3{margin:0 0 6px;font-size:16px;font-weight:650}
.feature p{margin:0;color:var(--muted);font-size:14px;line-height:1.5}
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;counter-reset:s}
.step{position:relative;padding:22px;background:var(--surface-2);border-radius:var(--radius);border:1px solid var(--line)}
.step::before{counter-increment:s;content:counter(s);position:absolute;top:-14px;left:20px;width:30px;height:30px;
  border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px}
.step h3{margin:8px 0 6px;font-size:15px}.step p{margin:0;color:var(--muted);font-size:13.5px}
.lp-prices{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px;align-items:stretch}
.lp-final{text-align:center;padding:56px 22px;margin:30px 0 10px;border-radius:18px;
  background:linear-gradient(135deg,var(--accent),#4c5bd4);color:#fff}
.lp-final h2{justify-content:center;color:#fff;font-size:28px}.lp-final h2::before{display:none}
.lp-final p{opacity:.9;margin:6px 0 22px}
.lp-final .btn{background:#fff;color:var(--accent)}
.lp-final .btn:hover{background:#eef}
.lp-foot{text-align:center;color:var(--faint);padding:30px 0;font-size:13px;border-top:1px solid var(--line);margin-top:20px}
.faq-item{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);margin-bottom:10px;overflow:hidden}
.faq-item summary{cursor:pointer;padding:15px 18px;font-weight:600;list-style:none;display:flex;align-items:center;gap:10px}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::before{content:"+";color:var(--accent-2);font-weight:700;font-size:18px;line-height:1}
.faq-item[open] summary::before{content:"–"}
.faq-item[open] summary{border-bottom:1px solid var(--line)}
.faq-a{padding:14px 18px;color:var(--muted);line-height:1.55}
.lp-blog{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px}
.lp-blog a.card{display:block;text-decoration:none;color:inherit}
.lp-blog a.card:hover{transform:translateY(-3px)}
.lp-blog h3{margin:0 0 6px;font-size:16px}
.article{max-width:760px;margin:0 auto}
.article h1{font-size:30px;margin-bottom:10px}
.article h2{font-size:20px;margin-top:28px}
.article p{color:var(--text);line-height:1.7;margin:12px 0}
.article ul{color:var(--text);line-height:1.7}

/* ---------- responsive ---------- */
@media(max-width:820px){
  .layout{flex-direction:column}
  .sidebar{width:auto;flex:none;height:auto;position:static;flex-direction:row;align-items:center;
    padding:10px 14px;overflow-x:auto;gap:6px}
  .sidebar .brand{padding:0 12px 0 4px;white-space:nowrap}
  .nav{flex-direction:row;gap:4px}
  .nav a span{display:none}
  .side-foot{border:0;margin:0;padding:0;margin-left:auto;display:flex;align-items:center;gap:6px}
  .side-foot .who .meta{display:none}
  .side-foot .frow{margin:0}
  .content{padding:20px 16px 50px}
}
