/* ============ Каркас приложения: сайдбар + контент (как в референсе) ============ */

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

/* ---------- Сайдбар ---------- */
.sidebar{
  width:var(--sidebar-w); flex-shrink:0;
  background:#fff; border-right:1px solid var(--border);
  display:flex; flex-direction:column;
  position:sticky; top:0; height:100vh;
}
.sidebar-head{
  display:flex; align-items:center; gap:10px;
  padding:16px 16px 12px;
}
.ws-logo{
  width:38px; height:38px; border-radius:10px;
  background:var(--accent); color:#fff;
  display:grid; place-items:center; font-weight:700; font-size:14px; flex-shrink:0;
}
.ws-meta{ min-width:0; line-height:1.2; }
.ws-name{ font-weight:600; font-size:14px; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ws-sub{ font-size:12px; color:var(--muted); }

.sidebar-search{ padding:4px 12px 10px; }
.sidebar-search .search-box{
  display:flex; align-items:center; gap:8px;
  background:var(--panel2); border:1px solid var(--border);
  border-radius:10px; padding:8px 10px;
}
.sidebar-search input{
  border:none; background:none; outline:none; width:100%;
  font-size:13px; color:var(--text);
}
.sidebar-search .kbd{
  font-size:11px; color:var(--muted); background:#fff;
  border:1px solid var(--border); border-radius:6px; padding:1px 6px;
}

.nav{ flex:1; overflow-y:auto; padding:4px 8px 8px; }
.nav-group-title{
  font-size:11px; text-transform:uppercase; letter-spacing:.04em;
  color:var(--muted-2); font-weight:700; padding:12px 10px 4px;
}
.nav-item{
  display:flex; align-items:center; gap:11px; width:100%;
  padding:9px 10px; margin:1px 0;
  border:none; background:none; text-align:left; cursor:pointer;
  border-radius:10px; color:#374151; font-size:14px; font-weight:500;
  transition:var(--transition-fast);
}
.nav-item:hover{ background:var(--chip); color:var(--text); }
.nav-item.is-active{ background:var(--accent-light); color:var(--accent-hover); font-weight:600; }
.nav-item svg{ width:18px; height:18px; flex-shrink:0; }
.nav-item .nav-label{ flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.nav-badge{
  background:var(--warning-light); color:var(--warning-hover);
  font-size:11px; font-weight:700; padding:1px 8px; border-radius:999px;
}

.sidebar-foot{ border-top:1px solid var(--border); padding:10px 12px; }
.push-btn{
  display:flex; align-items:center; gap:8px; justify-content:center;
  width:100%; padding:9px; margin-bottom:8px;
  background:var(--accent-light); color:var(--accent-hover);
  border:none; border-radius:10px; font-weight:600; font-size:13px; cursor:pointer;
}
.push-btn:hover{ background:rgba(13,148,136,0.16); }
.user-row{ display:flex; align-items:center; gap:10px; padding:6px 4px; }
.user-avatar{
  width:32px; height:32px; border-radius:8px; background:var(--chip);
  color:var(--text); display:grid; place-items:center; font-weight:600; font-size:12px; flex-shrink:0;
}
.user-meta{ min-width:0; line-height:1.2; }
.user-name{ font-size:13px; font-weight:600; }
.user-email{ font-size:11px; color:var(--muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }

/* ---------- Контентная часть ---------- */
.main{ flex:1; min-width:0; display:flex; flex-direction:column; }
.main-head{
  display:flex; align-items:flex-start; justify-content:space-between; gap:16px;
  padding:26px 30px 6px;
}
.greeting h1{ margin:0; font-size:26px; font-weight:700; letter-spacing:-0.3px; }
.greeting .date{ color:var(--muted); font-size:14px; margin-top:3px; text-transform:capitalize; }
.refresh-btn{
  display:inline-flex; align-items:center; gap:8px;
  background:#fff; border:1px solid var(--border); color:var(--text);
  border-radius:10px; padding:9px 14px; font-size:14px; font-weight:500; cursor:pointer;
}
.refresh-btn:hover{ background:var(--chip); }
.content{ padding:14px 30px 48px; max-width:1320px; width:100%; }

/* ---------- Унификация примитивов под референс ---------- */
.card{
  background:#fff; border:1px solid var(--border);
  border-radius:var(--radius); box-shadow:var(--shadow); padding:18px;
}
.btn{
  display:inline-flex; align-items:center; gap:8px; justify-content:center;
  border:1px solid transparent; border-radius:10px;
  background:var(--accent); color:#fff;
  padding:9px 16px; font-size:14px; font-weight:600; cursor:pointer;
  transition:var(--transition-fast); box-shadow:none;
}
.btn:hover{ background:var(--accent-hover); transform:none; }
.btn.secondary{ background:#fff; color:var(--text); border-color:var(--border); }
.btn.secondary:hover{ background:var(--chip); }
.btn.ok{ background:var(--ok); }
.btn.ok:hover{ background:var(--ok-hover); }
.btn.danger{ background:var(--danger); }
.btn.danger:hover{ background:var(--danger-hover); }

input[type="text"], input[type="number"], input[type="date"], input[type="search"], select, textarea{
  background:#fff; border:1px solid var(--border); border-radius:10px;
  color:var(--text); padding:9px 11px; font-size:14px; outline:none;
  transition:var(--transition-fast);
}
input:focus, select:focus, textarea:focus{ border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-light); }

/* ---------- Дашборд «Рабочий день» ---------- */
.alert-banner{
  display:flex; align-items:center; gap:14px;
  background:#fff; border:1px solid var(--border); border-left:4px solid var(--warning);
  border-radius:var(--radius); box-shadow:var(--shadow); padding:16px 18px; margin-bottom:22px;
}
.alert-banner .ab-icon{
  width:40px; height:40px; border-radius:10px; background:var(--warning-light);
  color:var(--warning-hover); display:grid; place-items:center; flex-shrink:0;
}
.alert-banner .ab-text h3{ margin:0; font-size:18px; font-weight:700; }
.alert-banner .ab-text p{ margin:2px 0 0; color:var(--muted); font-size:13px; }
.alert-banner .ab-spacer{ flex:1; }

.dash-section{ margin:26px 0 12px; display:flex; align-items:center; gap:8px; }
.dash-section .ds-title{ font-size:16px; font-weight:600; color:var(--text); display:flex; align-items:center; gap:8px; }
.dash-section .ds-title svg{ width:18px; height:18px; color:var(--muted); }
.dash-section .ds-count{ background:var(--chip); color:var(--muted); font-size:12px; font-weight:700; border-radius:999px; padding:1px 9px; }
.dash-section .ds-hint{ margin-left:auto; color:var(--muted-2); font-size:12px; }

.attention-card{ background:#fff; border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden; }
.attention-row{ display:flex; align-items:center; gap:14px; padding:16px 18px; }
.attention-row + .attention-row{ border-top:1px solid var(--border); }
.attention-row .ar-icon{
  width:36px; height:36px; border-radius:9px; background:var(--chip);
  color:var(--muted); display:grid; place-items:center; flex-shrink:0;
}
.attention-row.is-warn .ar-icon{ background:var(--warning-light); color:var(--warning-hover); }
.attention-row .ar-text{ min-width:0; }
.attention-row .ar-text b{ font-size:14px; font-weight:600; }
.attention-row .ar-text p{ margin:2px 0 0; color:var(--muted); font-size:13px; }
.attention-row .ar-link{ margin-left:auto; color:var(--warning-hover); font-weight:600; font-size:14px; cursor:pointer; white-space:nowrap; }
.attention-row .ar-link:hover{ text-decoration:underline; }

.stats-row{
  background:#fff; border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow);
  display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); overflow:hidden;
}
.stat-cell{ padding:18px 20px; border-left:1px solid var(--border); }
.stat-cell:first-child{ border-left:none; }
.stat-cell .sc-label{ color:var(--muted); font-size:13px; margin-bottom:6px; }
.stat-cell .sc-value{ font-size:26px; font-weight:700; letter-spacing:-0.5px; }
.stat-cell .sc-value small{ font-size:14px; color:var(--muted); font-weight:500; }
.stat-cell .sc-sub{ color:var(--muted-2); font-size:12px; margin-top:2px; }
.stat-cell .accent{ color:var(--accent); }
.stat-cell .warn{ color:var(--warning-hover); }

.money-grid{
  background:#fff; border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow);
  display:grid; grid-template-columns:1fr 1fr; overflow:hidden;
}
.money-cell{ padding:20px 22px; border-left:1px solid var(--border); }
.money-cell:first-child{ border-left:none; }
.money-cell .mc-label{ color:var(--muted); font-size:13px; }
.money-cell .mc-value{ font-size:28px; font-weight:700; margin-top:6px; letter-spacing:-0.5px; }
.money-cell .mc-value.warn{ color:var(--warning-hover); }
.money-cell .mc-sub{ color:var(--muted-2); font-size:12px; margin-top:2px; }

.quick-actions{ display:flex; gap:10px; flex-wrap:wrap; margin-top:12px; }

/* ---------- Адаптив ---------- */
@media (max-width: 640px){
  .sidebar{ position:fixed; left:0; top:0; z-index:200; transform:translateX(-100%); transition:transform .25s ease; box-shadow:var(--shadow-lg); }
  .sidebar.is-open{ transform:translateX(0); }
  .main-head{ padding:18px 16px 6px; }
  .content{ padding:12px 16px 40px; }
  .sidebar-toggle{ display:inline-flex !important; }
}
.sidebar-toggle{ display:none; align-items:center; justify-content:center; width:40px;height:40px; border:1px solid var(--border); background:#fff; border-radius:10px; cursor:pointer; }

/* ---------- Кнопка выхода ---------- */
.logout-btn{ margin-left:auto; flex-shrink:0; width:32px; height:32px; display:grid; place-items:center;
  border:1px solid var(--border); background:#fff; color:var(--muted); border-radius:8px; cursor:pointer; }
.logout-btn:hover{ background:var(--danger-light); color:var(--danger); border-color:var(--danger-light); }

/* ---------- Экран входа ---------- */
.login-overlay{ position:fixed; inset:0; z-index:1000; display:flex; align-items:center; justify-content:center; background:var(--bg); }
.login-overlay[hidden]{ display:none; }
.login-card{ width:340px; max-width:90vw; background:#fff; border:1px solid var(--border);
  border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); padding:28px; display:flex; flex-direction:column; gap:12px; text-align:center; }
.login-card .login-logo{ width:48px; height:48px; border-radius:12px; background:var(--accent); color:#fff;
  display:grid; place-items:center; font-weight:700; font-size:16px; margin:0 auto; }
.login-card h2{ margin:8px 0 0; font-size:20px; }
.login-card p{ margin:0 0 6px; }
.login-card input{ width:100%; }
.login-error{ color:var(--danger); font-size:13px; }
