/* Сметано — admin theme. "Чертёжный лист": paper grid, timber green, mono dims. */
:root{
  --paper:#f5f4ee; --grid:#e9e6da; --sheet:#fffdf8; --sheet-2:#faf8f1;
  --ink:#1b1f1a; --ink-2:#5b5f58; --ink-3:#8a8d83;
  --line:#e3e0d5; --line-2:#d3d0c2;
  --pine:#2f5d4f; --pine-d:#244a40; --pine-soft:#e6efea;
  --amber:#bd6f24; --amber-soft:#f5e8d6;
  --ok:#2f7d5b; --ok-soft:#e3f0e8; --warn:#a8501c; --warn-soft:#f6e6dc;
  --radius:11px; --r-sm:7px;
  --mono:ui-monospace,"SFMono-Regular","Cascadia Code",Consolas,monospace;
  --ui:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
  --shadow:0 1px 2px rgba(30,40,30,.05),0 6px 22px rgba(30,40,30,.06);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0; font-family:var(--ui); color:var(--ink); font-size:15px; line-height:1.5;
  background:var(--paper);
  background-image:linear-gradient(var(--grid) 1px,transparent 1px),
                   linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:26px 26px; background-position:-1px -1px;
}
a{color:var(--pine);text-decoration:none}
a:hover{color:var(--pine-d);text-decoration:underline;text-underline-offset:2px}
h1,h2,h3{color:var(--ink);font-weight:650;letter-spacing:-.01em;margin:.2em 0 .5em}
h1{font-size:1.7rem} h2{font-size:1.15rem;margin-top:1.4em} h3{font-size:1rem}
.mono,td.num{font-family:var(--mono)}
.muted{color:var(--ink-2)} .flag{color:var(--warn)}

/* ---- app shell: title-block sidebar + sheet ---- */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{
  position:sticky;top:0;align-self:start;height:100vh;overflow:auto;
  background:var(--sheet);border-right:1px solid var(--line);
  display:flex;flex-direction:column;padding:18px 14px;gap:4px;
}
.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 16px}
.brand .logo{width:34px;height:34px;flex:none}
.brand b{font-size:1.15rem;letter-spacing:.02em}
.brand small{display:block;font-family:var(--mono);font-size:10px;color:var(--ink-3);
  letter-spacing:.14em;text-transform:uppercase;margin-top:1px}
.nav{display:flex;flex-direction:column;gap:2px;margin-top:4px}
.nav a{
  display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--r-sm);
  color:var(--ink-2);font-weight:500;border-left:2px solid transparent;
}
.nav a svg{width:17px;height:17px;flex:none;opacity:.8}
.nav a:hover{background:var(--sheet-2);color:var(--ink);text-decoration:none}
.nav a.active{background:var(--pine-soft);color:var(--pine-d);border-left-color:var(--amber)}
.nav a.active svg{opacity:1;color:var(--pine)}
.side .spacer{flex:1}
.side .foot{border-top:1px dashed var(--line-2);padding:14px 10px 4px;font-size:12.5px}
.side .foot .k{color:var(--ink-3);font-family:var(--mono);font-size:10.5px;
  letter-spacing:.1em;text-transform:uppercase}
.side .foot .v{color:var(--ink);font-family:var(--mono)}
.btn-out{display:inline-block;margin-top:12px;padding:7px 13px;border:1px solid var(--line-2);
  border-radius:var(--r-sm);color:var(--ink-2);font-weight:500;background:var(--sheet)}
.btn-out:hover{border-color:var(--pine);color:var(--pine);text-decoration:none}

.main{padding:26px 34px 60px;max-width:1060px}
.sheet-head{margin-bottom:18px}
.sheet-head .ruler{height:9px;margin:6px 0 0;
  background:repeating-linear-gradient(90deg,var(--line-2) 0 1px,transparent 1px 13px);
  border-bottom:1px solid var(--line-2)}
.sheet-head .eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink-3)}

/* ---- cards ---- */
.card{background:var(--sheet);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:18px 20px;margin-bottom:18px}
.card.tight{padding:0;overflow:hidden}

/* ---- tables ---- */
table{border-collapse:collapse;width:100%;font-size:14px}
thead th{font-family:var(--mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-3);text-align:left;font-weight:600;padding:11px 16px;
  border-bottom:1px solid var(--line)}
tbody td{padding:12px 16px;border-bottom:1px solid var(--line)}
tbody tr:last-child td{border-bottom:0}
tbody tr:hover{background:var(--sheet-2)}
td.num,th.num{text-align:right;font-family:var(--mono);white-space:nowrap}

/* ---- badges ---- */
.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:12px;font-weight:600;
  font-family:var(--mono);letter-spacing:.02em}
.badge.ok{background:var(--ok-soft);color:var(--ok)}
.badge.review{background:var(--amber-soft);color:var(--amber)}
.badge.warn{background:var(--warn-soft);color:var(--warn)}
.badge.muted{background:var(--sheet-2);color:var(--ink-2);border:1px solid var(--line)}

/* ---- forms ---- */
label{display:block;font-weight:550;margin:14px 0 6px;font-size:14px}
input,textarea,select{
  width:100%;font-family:var(--ui);font-size:14px;color:var(--ink);background:var(--sheet);
  border:1px solid var(--line-2);border-radius:var(--r-sm);padding:9px 11px;transition:.12s}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--pine);
  box-shadow:0 0 0 3px var(--pine-soft)}
textarea{font-family:var(--mono);font-size:13px;line-height:1.55;resize:vertical;min-height:90px}
input[type=checkbox]{width:auto;accent-color:var(--pine);vertical-align:middle}
.inline{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.inline input{width:auto}
button,.btn{display:inline-block;cursor:pointer;font-family:var(--ui);font-weight:600;font-size:14px;
  color:#fff;background:var(--pine);border:1px solid var(--pine);border-radius:var(--r-sm);
  padding:9px 16px;transition:.12s}
button:hover,.btn:hover{background:var(--pine-d);border-color:var(--pine-d)}
button.secondary{background:var(--sheet);color:var(--ink-2);border-color:var(--line-2)}
button.secondary:hover{background:var(--sheet-2);color:var(--ink)}
button.danger{background:var(--sheet);color:var(--warn);border-color:var(--warn-soft)}
button.danger:hover{background:var(--warn-soft)}
.actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}

/* ---- login ---- */
.login-wrap{display:grid;place-items:center;min-height:100vh;padding:20px}
.login{width:100%;max-width:400px}
.login .card{padding:26px 26px 24px}
.login .brand{padding:0 0 6px}
.login .sub{color:var(--ink-2);margin:0 0 14px;font-size:14px}
.login .err{background:var(--warn-soft);color:var(--warn);padding:9px 12px;border-radius:var(--r-sm);
  font-size:13.5px;margin-bottom:8px}
.login button{width:100%;margin-top:18px;padding:11px}

/* ---- file tabs (skills) ---- */
.tabs{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.tabs a{font-family:var(--mono);font-size:13px;padding:7px 13px;border:1px solid var(--line-2);
  border-radius:20px;color:var(--ink-2)}
.tabs a:hover{border-color:var(--pine);color:var(--pine);text-decoration:none}
.tabs a.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ---- toast ---- */
.toast{position:fixed;bottom:22px;right:22px;background:var(--ink);color:#fff;
  padding:11px 18px;border-radius:var(--r-sm);box-shadow:var(--shadow);font-size:14px;
  opacity:0;transform:translateY(8px);transition:.25s;z-index:50}
.toast.show{opacity:1;transform:none}

/* ---- horizontal subsection tabs ---- */
.subtabs{display:flex;gap:6px;flex-wrap:wrap;margin:6px 0 16px;
  border-bottom:1px solid var(--line);padding-bottom:10px}
.subtabs a{font-size:14px;font-weight:600;padding:7px 14px;border-radius:20px;
  color:var(--ink-2);border:1px solid transparent}
.subtabs a:hover{background:var(--sheet-2);color:var(--ink);text-decoration:none}
.subtabs a.active{background:var(--pine);color:#fff;border-color:var(--pine)}
.tabpanel{display:none}
.tabpanel.show{display:block}

/* ---- settings rows ---- */
.setrow{display:flex;align-items:center;gap:14px;padding:10px 2px;border-bottom:1px solid var(--line)}
.setrow:last-of-type{border-bottom:0}
.setrow .lbl{flex:1;font-weight:500}
.setrow .ctl{flex:none;width:170px}
.setrow .ctl>input,.setrow .ctl>select{margin:0}
.setrow .ctl.bool{width:auto}
.setrow .ctl.bool input{width:20px;height:20px}
.card>form>h3{margin-top:0}

.savebar{display:flex;align-items:center;gap:14px;margin-top:12px}
.savebar .dirty{font-size:13px;color:var(--amber);display:none}
.savebar.is-dirty .dirty{display:inline}

/* ---- responsive ---- */
@media(max-width:820px){
  .app{grid-template-columns:1fr}
  .side{position:static;height:auto;flex-direction:row;flex-wrap:wrap;align-items:center;
    border-right:0;border-bottom:1px solid var(--line);padding:10px 14px;gap:8px}
  .side .brand{padding:0;margin-right:auto}
  .side .spacer,.side .foot{display:none}
  .nav{flex-direction:row;flex-wrap:wrap}
  .nav a{padding:7px 10px;border-left:0;border-bottom:2px solid transparent}
  .nav a.active{border-left:0;border-bottom-color:var(--amber)}
  .main{padding:20px 16px 50px}
}
