/* Rino Dashboard — тема (CR-065). База — макет «Rino — Панель управления». */
:root{
  --black:#0A0A0A; --ink:#0E0E0E; --panel:#141414; --panel-2:#181818; --panel-3:#1E1E1E;
  --line:#262626; --line-2:#2F2F2F;
  --txt:#FFFFFF; --txt-2:#9A9A9A; --txt-3:#6A6A6A; --txt-4:#525252;
  --accent:#FEBE03; --accent-dim:#3A2E05;
  --ok:#7CC796; --ok-dim:#16261C; --danger:#E5675A;
  --font:"Work Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --display:"Oswald","Work Sans",sans-serif;
  --sidebar-w:280px;
}
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; background:var(--black); color:var(--txt); font-family:var(--font); -webkit-font-smoothing:antialiased; }
a{ color:inherit; }
::selection{ background:var(--accent); color:#000; }
::-webkit-scrollbar{ width:10px; height:10px; }
::-webkit-scrollbar-track{ background:transparent; }
::-webkit-scrollbar-thumb{ background:#262626; }
::-webkit-scrollbar-thumb:hover{ background:#333; }
.hidden{ display:none !important; }

.app{ display:flex; min-height:100vh; }

/* ================= SIDEBAR ================= */
.sidebar{ width:var(--sidebar-w); flex:0 0 var(--sidebar-w); background:var(--ink); border-right:1px solid var(--line); display:flex; flex-direction:column; position:sticky; top:0; height:100vh; overflow:hidden; }
.brand{ display:flex; align-items:flex-start; justify-content:space-between; padding:26px 24px 22px; border-bottom:1px solid var(--line); }
.brand .mark{ font-family:var(--display); font-weight:700; font-size:30px; letter-spacing:0.02em; line-height:.9; text-transform:lowercase; }
.brand .mark .dot{ color:var(--accent); }
.brand .sub{ display:block; font-size:9px; letter-spacing:0.34em; text-transform:uppercase; color:var(--txt-3); margin-top:8px; font-weight:600; }

.nav{ flex:1; overflow-y:auto; padding:14px 14px 8px; display:flex; flex-direction:column; gap:1px; }
.nav-item{ display:flex; align-items:center; gap:14px; padding:11px 12px; color:var(--txt-2); font-size:13.5px; font-weight:500; letter-spacing:0.06em; text-transform:uppercase; cursor:pointer; border-left:2px solid transparent; transition:background .14s, color .14s, border-color .14s; white-space:nowrap; user-select:none; }
.nav-item svg{ width:18px; height:18px; flex:0 0 18px; stroke-width:1.6; }
.nav-item:hover{ color:var(--txt); background:#161616; }
.nav-item.active{ color:var(--txt); background:#171717; border-left-color:var(--accent); }
.nav-item.active svg{ color:var(--accent); }

.sys{ border-top:1px solid var(--line); padding:16px 22px 14px; display:flex; flex-direction:column; gap:11px; background:#0C0C0C; }
.sys-head{ font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:var(--txt-4); font-weight:600; }
.sys-row{ display:flex; align-items:center; justify-content:space-between; font-size:12.5px; color:var(--txt-2); }
.sys-row .v{ color:var(--txt); font-variant-numeric:tabular-nums; }
.sys-row .dot{ display:inline-flex; align-items:center; gap:7px; }
.sys-row .dot::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--txt-3); box-shadow:0 0 0 3px rgba(150,150,150,.12); }
.sys-row.ok .dot::before{ background:var(--ok); box-shadow:0 0 0 3px rgba(124,199,150,.14); }
.sys-row.bad .dot::before{ background:var(--danger); box-shadow:0 0 0 3px rgba(229,103,90,.14); }

.acct{ display:flex; align-items:center; justify-content:space-between; padding:13px 22px; border-top:1px solid var(--line); background:#0C0C0C; }
.acct .who{ display:flex; flex-direction:column; gap:2px; }
.acct .who b{ font-size:13px; font-weight:600; }
.acct .who span{ font-size:11px; color:var(--txt-4); font-family:var(--mono); }
.ver{ display:flex; align-items:center; justify-content:space-between; padding:10px 22px; font-family:var(--mono); font-size:11px; color:var(--txt-4); border-top:1px solid var(--line); background:#080808; }

/* ================= MAIN ================= */
.main{ flex:1; min-width:0; display:flex; flex-direction:column; }
.topbar{ display:flex; align-items:center; gap:16px; padding:0 40px; height:64px; border-bottom:1px solid var(--line); position:sticky; top:0; z-index:5; background:rgba(10,10,10,.86); backdrop-filter:blur(8px); }
.topbar .crumb{ font-size:14px; letter-spacing:0.05em; text-transform:uppercase; font-weight:600; }
.topbar .crumb .pre{ color:var(--txt-4); margin-right:10px; }
.topbar .spacer{ flex:1; }
.topbar .pill{ font-family:var(--mono); font-size:12px; color:var(--txt-2); border:1px solid var(--line); padding:6px 12px; display:inline-flex; align-items:center; gap:8px; cursor:pointer; }
.topbar .pill::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--txt-3); }
.topbar .pill.ok::before{ background:var(--ok); }
.topbar .pill:hover{ border-color:var(--line-2); color:var(--txt); }

.content{ padding:48px 56px 80px; max-width:1280px; width:100%; }

.page-head{ margin-bottom:34px; }
.kicker{ display:flex; align-items:center; gap:13px; margin-bottom:18px; }
.kicker .bar{ width:34px; height:4px; background:var(--accent); }
.kicker .lbl{ font-size:12px; letter-spacing:0.28em; text-transform:uppercase; color:var(--txt-3); font-weight:600; }
.page-head h1{ font-family:var(--display); font-weight:600; font-size:44px; line-height:1.02; letter-spacing:0.01em; margin:0 0 14px; }
.page-head p{ font-size:16px; line-height:1.5; color:var(--txt-2); max-width:760px; margin:0; }
.page-head p b{ color:var(--accent); font-weight:600; }

/* ---- cards ---- */
.card{ border:1px solid var(--line); background:var(--panel); margin-bottom:26px; }
.card-head{ display:flex; align-items:center; gap:13px; padding:18px 26px; border-bottom:1px solid var(--line); background:#121212; }
.card-head .ico{ width:30px; height:30px; flex:0 0 30px; display:grid; place-items:center; border:1px solid var(--line-2); background:#0E0E0E; color:var(--accent); }
.card-head .ico svg{ width:16px; height:16px; }
.card-head h2{ font-size:14px; font-weight:600; letter-spacing:0.18em; text-transform:uppercase; margin:0; }
.card-head .tag{ margin-left:auto; font-family:var(--mono); font-size:11px; color:var(--txt-3); letter-spacing:0.04em; }
.card-body{ padding:26px; }

/* ---- form atoms ---- */
.field{ display:flex; flex-direction:column; gap:9px; }
label.flbl{ font-size:11.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--txt-3); font-weight:600; }
label.flbl .opt{ color:var(--txt-4); }
.inp, .sel{ width:100%; background:#0C0C0C; border:1px solid var(--line-2); color:var(--txt); font-family:var(--font); font-size:15px; padding:13px 15px; transition:border-color .14s, background .14s; appearance:none; }
.inp::placeholder{ color:var(--txt-4); }
.inp:focus, .sel:focus{ outline:none; border-color:var(--accent); background:#0E0E0E; }
.sel{ background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236A6A6A' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>"); background-repeat:no-repeat; background-position:right 14px center; padding-right:40px; cursor:pointer; color:var(--txt-2); }

/* ---- buttons ---- */
.btn{ font-family:var(--font); font-size:13px; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; padding:13px 22px; border:1px solid transparent; cursor:pointer; transition:all .14s; white-space:nowrap; display:inline-flex; align-items:center; gap:9px; background:transparent; color:var(--txt); }
.btn:disabled{ opacity:.45; cursor:not-allowed; }
.btn-primary{ background:var(--accent); color:#0A0A0A; }
.btn-primary:hover:not(:disabled){ background:#ffce3d; box-shadow:0 0 0 3px rgba(254,190,3,.16); }
.btn-ghost{ background:transparent; border-color:var(--line-2); color:var(--txt); }
.btn-ghost:hover:not(:disabled){ border-color:var(--accent); color:var(--accent); }
.btn-danger{ background:transparent; border-color:#3a2422; color:var(--danger); }
.btn-danger:hover:not(:disabled){ border-color:var(--danger); background:rgba(229,103,90,.08); }
.btn-sm{ padding:9px 15px; font-size:12px; }
.btn-block{ width:100%; justify-content:center; padding:16px; font-size:14px; }

.inline-create{ display:flex; align-items:flex-end; gap:18px; }
.inline-create .field{ flex:1; max-width:420px; }

/* ---- leader / employee row ---- */
.lead-row{ display:flex; align-items:center; gap:20px; padding:18px 22px; border:1px solid var(--line); background:#101010; margin-bottom:10px; flex-wrap:wrap; }
.lead-avatar{ width:46px; height:46px; flex:0 0 46px; border:1px solid var(--line-2); background:#0C0C0C; display:grid; place-items:center; font-family:var(--display); font-weight:600; font-size:20px; color:var(--accent); }
.lead-meta{ display:flex; flex-direction:column; gap:5px; min-width:0; }
.lead-meta .nm{ font-size:16px; font-weight:600; }
.lead-meta .nm .role{ color:var(--txt-3); font-weight:400; }
.lead-meta .sub{ font-family:var(--mono); font-size:12px; color:var(--txt-3); letter-spacing:0.02em; word-break:break-all; }
.lead-meta .sub b{ color:var(--txt-2); font-weight:500; }
.lead-actions{ margin-left:auto; display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end; }

.badge{ display:inline-flex; align-items:center; gap:8px; font-size:11.5px; font-weight:600; letter-spacing:0.12em; text-transform:uppercase; padding:8px 13px; border:1px solid var(--line-2); color:var(--txt-2); }
.badge.ok{ color:var(--ok); border-color:#234334; background:var(--ok-dim); }
.badge.ok::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--ok); }
.badge.warn{ color:var(--accent); border-color:var(--accent-dim); background:#1a1505; }
.badge.muted{ color:var(--txt-3); }
.badge.folder{ color:var(--txt-2); border-color:var(--line-2); background:#0E0E0E; cursor:pointer; text-transform:none; letter-spacing:0.02em; font-weight:500; text-decoration:none; }
.badge.folder:hover{ color:var(--accent); border-color:var(--accent); }
.badge.wa{ color:var(--ok); border-color:#234334; background:var(--ok-dim); cursor:pointer; text-transform:none; letter-spacing:0; }
.badge.wa:hover{ color:var(--danger); border-color:var(--danger); background:rgba(229,103,90,.08); }

.subhead{ display:flex; align-items:center; gap:13px; margin:28px 0 16px; }
.subhead .t{ font-size:12px; letter-spacing:0.2em; text-transform:uppercase; color:var(--txt-2); font-weight:600; }
.subhead .ln{ flex:1; height:1px; background:var(--line); }
.sep{ height:1px; background:var(--line); margin:26px 0; }

.dept-row{ display:flex; align-items:flex-end; gap:18px; flex-wrap:wrap; }
.dept-row .field{ flex:1 1 240px; }
.dept-row .field.narrow{ flex:0 1 220px; }
.dept-block{ border:1px solid var(--line); background:#0E0E0E; padding:16px 18px; margin-bottom:14px; }
.dept-block .dept-title{ font-size:13px; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; color:var(--txt-2); margin-bottom:12px; display:flex; align-items:center; gap:10px; }
.dept-block .dept-title .ln{ flex:1; height:1px; background:var(--line); }

.emp-grid{ display:grid; grid-template-columns:1fr 1fr; gap:20px 30px; }
.emp-grid .span2{ grid-column:1 / -1; }
.muted-note{ color:var(--txt-3); font-size:13px; }
.err-banner{ border:1px solid #3a2422; background:rgba(229,103,90,.08); color:var(--danger); padding:14px 18px; margin-bottom:20px; font-size:14px; }

/* ---- tables (sessions/logs/models) ---- */
.tbl{ width:100%; border-collapse:collapse; font-size:13.5px; }
.tbl th{ text-align:left; font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--txt-4); font-weight:600; padding:10px 14px; border-bottom:1px solid var(--line); }
.tbl td{ padding:12px 14px; border-bottom:1px solid var(--line); color:var(--txt-2); vertical-align:top; }
.tbl tr:hover td{ background:#101010; }
.tbl td .mono{ font-family:var(--mono); font-size:12px; color:var(--txt-3); }
.logbox{ font-family:var(--mono); font-size:12px; line-height:1.55; color:var(--txt-2); background:#080808; border:1px solid var(--line); padding:16px 18px; max-height:62vh; overflow:auto; white-space:pre-wrap; word-break:break-word; }
.logbox .lvl-err{ color:var(--danger); }
.logbox .lvl-warn{ color:var(--accent); }

/* ---- spinner / empty ---- */
.spinner{ width:18px; height:18px; border:2px solid var(--line-2); border-top-color:var(--accent); border-radius:50%; animation:spin .7s linear infinite; display:inline-block; vertical-align:middle; }
@keyframes spin{ to{ transform:rotate(360deg); } }
.loading{ color:var(--txt-3); font-size:14px; display:flex; align-items:center; gap:12px; padding:30px 0; }
.empty{ color:var(--txt-4); font-size:14px; padding:24px; text-align:center; border:1px dashed var(--line); }

/* ---- toasts ---- */
.toasts{ position:fixed; right:24px; bottom:24px; display:flex; flex-direction:column; gap:10px; z-index:50; }
.toast{ border:1px solid var(--line-2); background:#141414; color:var(--txt); padding:13px 18px; font-size:13.5px; min-width:260px; max-width:420px; box-shadow:0 8px 30px rgba(0,0,0,.5); animation:slidein .18s ease; }
.toast.ok{ border-color:#234334; } .toast.ok b{ color:var(--ok); }
.toast.err{ border-color:#3a2422; } .toast.err b{ color:var(--danger); }
.toast b{ display:block; font-size:11px; letter-spacing:0.14em; text-transform:uppercase; margin-bottom:4px; color:var(--txt-3); }
@keyframes slidein{ from{ transform:translateY(8px); opacity:0; } }

/* ---- modal (confirm) ---- */
.modal-bg{ position:fixed; inset:0; background:rgba(0,0,0,.66); display:grid; place-items:center; z-index:60; }
.modal{ border:1px solid var(--line-2); background:var(--panel); width:440px; max-width:92vw; }
.modal .mh{ padding:18px 22px; border-bottom:1px solid var(--line); font-size:13px; letter-spacing:0.14em; text-transform:uppercase; font-weight:600; }
.modal .mb{ padding:22px; font-size:14.5px; line-height:1.5; color:var(--txt-2); }
.modal .mf{ padding:16px 22px; border-top:1px solid var(--line); display:flex; gap:12px; justify-content:flex-end; }

/* ---- code / pre (reconcile report, oauth) ---- */
pre.report{ font-family:var(--mono); font-size:12px; line-height:1.5; color:var(--txt-2); background:#080808; border:1px solid var(--line); padding:14px 16px; overflow:auto; max-height:340px; white-space:pre-wrap; }
.copyrow{ display:flex; align-items:center; gap:10px; }
.copyrow .val{ flex:1; font-family:var(--mono); font-size:12px; color:var(--txt-2); background:#0C0C0C; border:1px solid var(--line-2); padding:11px 13px; overflow:auto; white-space:nowrap; }

@media (max-width:1080px){ .emp-grid{ grid-template-columns:1fr; } .content{ padding:36px 32px 70px; } }
/* Десктоп-онли контракт админ-панели (audit WP-E.5.3): раньше при <=880px сайдбар
   просто скрывался (display:none) → разделы становились «невидимыми» без альтернативы.
   Теперь на узких экранах показываем ЯВНЫЙ экран с причиной и критичным действием
   (переход в адаптированный кабинет сотрудника), а не безнавигационную админку. */
.mobile-block{ display:none; }
@media (max-width:880px){
  .app{ display:none; }
  .mobile-block{ display:flex; min-height:100vh; align-items:center; justify-content:center;
                 padding:24px; background:var(--black); }
  .mb-card{ max-width:440px; text-align:center; }
  .mb-mark{ font-family:var(--display); font-size:30px; font-weight:700; margin-bottom:14px; }
  .mb-mark span{ color:var(--accent); }
  .mb-card h1{ font-size:20px; margin:0 0 10px; color:var(--txt); }
  .mb-card p{ color:var(--txt-2); font-size:14px; line-height:1.5; margin:8px 0; }
  .mb-actions{ display:flex; flex-direction:column; gap:10px; margin-top:18px; }
  .mb-btn{ display:flex; align-items:center; justify-content:center; min-height:44px;
           padding:12px 16px; border-radius:10px; background:var(--accent); color:#000;
           text-decoration:none; font-weight:600; }
  .mb-btn.mb-out{ background:transparent; color:var(--txt-2); border:1px solid var(--line); }
}
