
/* ============================================================
   v11-polish-final.css
   Финальная полировка: сетка, календарь, зарплата, сотрудники, модалки, адаптация.
   Загружается последним поверх всех старых CSS.
   ============================================================ */

:root{
  --v11-max:1280px;
  --v11-gap:18px;
  --v11-blue:#2f62d4;
  --v11-blue-soft:#eef4ff;
  --v11-line:#dbe5f2;
  --v11-card:#ffffff;
  --v11-bg:#f4f7fb;
  --v11-text:#111827;
  --v11-muted:#6b7688;
  --v11-shadow:0 18px 46px rgba(17,24,39,.075);
}

html,body{overflow-x:hidden!important;background:var(--v11-bg)!important}
.app{width:100%!important;min-width:0!important;overflow-x:hidden!important}
.sidebar{flex:0 0 var(--nav-w, 260px)!important;min-width:var(--nav-w, 260px)!important}
.main{
  width:100%!important;
  min-width:0!important;
  max-width:calc(100vw - var(--nav-w, 260px))!important;
  padding:24px 28px 36px!important;
  overflow-x:hidden!important;
}
#pageContent{
  width:min(100%, var(--v11-max))!important;
  max-width:100%!important;
  margin:0 auto!important;
  display:block!important;
}
#pageContent > *{max-width:100%!important;min-width:0!important}

/* ПК: кнопка Меню не нужна */
@media (min-width:981px){
  .mobile-menu-btn,
  button.mobile-menu-btn,
  .topbar .mobile-menu-btn{display:none!important}
  .topbar{grid-template-columns:1fr auto!important;align-items:center!important}
}

/* Единая сетка и ровные карточки */
.grid{display:grid!important;gap:var(--v11-gap)!important;align-items:stretch!important;width:100%!important;max-width:100%!important}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))!important}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))!important}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))!important}
.card,
.metric,
.quick-card,
.salary-v5-card,
.salary-v5-metric{
  min-width:0!important;
  max-width:100%!important;
  border-radius:22px!important;
  box-shadow:var(--v11-shadow)!important;
}
.card{padding:22px!important}
.card-head{align-items:flex-start!important;gap:14px!important;margin-bottom:16px!important}
.card-head .btn{flex:0 0 auto!important}
.metric{min-height:118px!important;display:flex!important;flex-direction:column!important;justify-content:center!important}
.metric .value{line-height:1.05!important}
.table-wrap{max-width:100%!important;overflow:auto!important;border-radius:20px!important}
.toolbar,.toolbar-compact{gap:14px!important;align-items:end!important;max-width:100%!important;min-width:0!important}
.field{min-width:0!important;max-width:100%!important}
.input,.textarea,.select,.custom-select,.custom-select__trigger{max-width:100%!important;min-width:0!important}
.actions{display:flex!important;gap:10px!important;align-items:center!important;flex-wrap:wrap!important}
.btn{white-space:nowrap!important}

/* ============================================================
   ГРАФИК / КАЛЕНДАРЬ
   ============================================================ */
.calendar-panel{
  width:100%!important;
  max-width:100%!important;
  overflow:hidden!important;
  padding:24px!important;
  border-radius:24px!important;
}
.calendar-filters{
  display:grid!important;
  grid-template-columns:minmax(128px,160px) minmax(190px,1fr) minmax(220px,1fr) auto!important;
  gap:16px!important;
  align-items:end!important;
  margin-bottom:22px!important;
}
.calendar-filters .field{margin:0!important}
.calendar-filters .btn{height:44px!important;border-radius:14px!important;padding-inline:18px!important}
.calendar-shell{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:20px!important;
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  overflow:hidden!important;
}
.calendar-shell > div:first-child,
.calendar-shell > *{min-width:0!important;max-width:100%!important}
.calendar-head{
  display:grid!important;
  grid-template-columns:44px 1fr 44px!important;
  align-items:center!important;
  gap:12px!important;
  margin:0 0 16px!important;
}
.calendar-title{
  text-align:center!important;
  font-size:20px!important;
  line-height:1.15!important;
  font-weight:900!important;
  color:var(--v11-text)!important;
}
.calendar-grid{
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  display:grid!important;
  grid-template-columns:repeat(7,minmax(0,1fr))!important;
  gap:10px!important;
  overflow:hidden!important;
}
.calendar-weekday{
  min-width:0!important;
  padding:0 0 8px!important;
  text-align:center!important;
  color:var(--v11-muted)!important;
  font-size:12px!important;
  font-weight:900!important;
}
.calendar-day{
  min-width:0!important;
  max-width:100%!important;
  min-height:108px!important;
  padding:8px!important;
  border-radius:16px!important;
  overflow:hidden!important;
  display:flex!important;
  flex-direction:column!important;
  gap:6px!important;
  contain:layout paint!important;
}
.calendar-date{
  display:flex!important;
  align-items:center!important;
  justify-content:space-between!important;
  gap:6px!important;
  min-width:0!important;
  margin-bottom:2px!important;
}
.calendar-date strong{font-size:13px!important;line-height:1!important}
.calendar-date span{font-size:10px!important;line-height:1!important;color:var(--v11-muted)!important}
.calendar-event{
  display:block!important;
  width:100%!important;
  max-width:100%!important;
  min-width:0!important;
  padding:5px 6px!important;
  border-radius:9px!important;
  background:var(--v11-blue-soft)!important;
  color:#234fb0!important;
  font-size:10.4px!important;
  line-height:1.14!important;
  font-weight:900!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.calendar-event small{
  display:block!important;
  margin-top:2px!important;
  color:#53647c!important;
  font-size:9.2px!important;
  line-height:1.12!important;
  font-weight:700!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
.calendar-side{
  width:100%!important;
  max-width:100%!important;
  position:static!important;
  top:auto!important;
  padding:18px!important;
  overflow:hidden!important;
}
.day-detail-list{
  display:grid!important;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr))!important;
  gap:12px!important;
}
.day-detail-item{
  min-width:0!important;
  max-width:100%!important;
  overflow:hidden!important;
  border-radius:16px!important;
}
.day-detail-item strong,
.day-detail-item span{
  display:block!important;
  min-width:0!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  white-space:nowrap!important;
}
@media (min-width:1600px){
  .calendar-shell{grid-template-columns:minmax(0,1fr) minmax(280px,320px)!important;align-items:start!important}
  .calendar-side{position:sticky!important;top:88px!important}
}
@media (max-width:760px){
  .calendar-panel{padding:16px!important;border-radius:20px!important}
  .calendar-filters{grid-template-columns:1fr!important;gap:12px!important;margin-bottom:16px!important}
  .calendar-grid{gap:5px!important}
  .calendar-day{min-height:72px!important;padding:5px!important;border-radius:11px!important}
  .calendar-date strong{font-size:11px!important}
  .calendar-date span{font-size:8.5px!important}
  .calendar-event{font-size:8.8px!important;padding:3px 4px!important;border-radius:7px!important}
  .calendar-event small{display:none!important}
  .day-detail-list{grid-template-columns:1fr!important}
}

/* ============================================================
   ЗАРПЛАТА: компактный первый блок и ровная сетка
   ============================================================ */
.salary-v5,
.salary-v5-page{width:100%!important;max-width:100%!important;gap:14px!important}
.salary-v5-hero{
  width:100%!important;
  max-width:100%!important;
  padding:16px 18px!important;
  border-radius:20px!important;
  overflow:visible!important;
  display:block!important;
}
.salary-v5-hero::before{height:3px!important}
.salary-v5-hero__top{
  display:grid!important;
  grid-template-columns:minmax(0,1fr) auto!important;
  gap:12px!important;
  align-items:start!important;
  margin:0 0 12px!important;
}
.salary-v5-title{display:flex!important;gap:11px!important;align-items:flex-start!important;min-width:0!important}
.salary-v5-title__icon{width:36px!important;height:36px!important;border-radius:11px!important;flex:0 0 auto!important}
.salary-v5-title>div:last-child{min-width:0!important}
.salary-v5-title>div:last-child h2{font-size:17px!important;line-height:1.15!important;margin:0!important;font-weight:900!important}
.salary-v5-title>div:last-child p{font-size:12px!important;line-height:1.35!important;margin-top:4px!important;max-width:66ch!important}
.salary-v5-period{font-size:12px!important;line-height:1.2!important;white-space:nowrap!important;margin:0!important;color:var(--v11-muted)!important}
.salary-v5-controls{
  display:grid!important;
  grid-template-columns:minmax(118px,150px) minmax(185px,1.1fr) minmax(160px,1fr) minmax(180px,1fr)!important;
  gap:10px!important;
  align-items:end!important;
  width:100%!important;
}
.salary-v5-field{gap:6px!important;min-width:0!important;margin:0!important}
.salary-v5-label{font-size:11.5px!important;line-height:1!important;font-weight:800!important}
.salary-v5-input,
.salary-v5-select__trigger{height:40px!important;min-height:40px!important;border-radius:11px!important;padding:8px 11px!important;font-size:12.8px!important}
.salary-v5-icon-btn{width:30px!important;height:30px!important;border-radius:9px!important}
.salary-v5-select__arrow{width:18px!important;height:18px!important;flex:0 0 auto!important}
.salary-v5-actions{
  grid-column:1/-1!important;
  display:flex!important;
  flex-wrap:wrap!important;
  gap:8px!important;
  align-items:center!important;
  justify-content:flex-start!important;
  margin:0!important;
}
.salary-v5-btn{min-height:38px!important;border-radius:11px!important;padding:8px 12px!important;font-size:12.5px!important;line-height:1.1!important}
.salary-v5-summary{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:12px!important;width:100%!important}
.salary-v5-metric{min-height:94px!important;padding:14px!important;border-radius:18px!important}
.salary-v5-metric strong{font-size:23px!important;line-height:1.05!important}
.salary-v5-main{display:grid!important;grid-template-columns:minmax(0,1.35fr) minmax(280px,.65fr)!important;gap:14px!important;width:100%!important;max-width:100%!important}
.salary-v5-card{min-width:0!important;max-width:100%!important;overflow:hidden!important}
.salary-v5-card__body{min-width:0!important;max-width:100%!important;overflow:auto!important}
.salary-v5-statement{max-width:100%!important;overflow:hidden!important}
@media(max-width:1180px){
  .salary-v5-hero__top{grid-template-columns:1fr!important}
  .salary-v5-controls{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .salary-v5-summary{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .salary-v5-main{grid-template-columns:1fr!important}
}
@media(max-width:640px){
  .salary-v5-controls,.salary-v5-summary{grid-template-columns:1fr!important}
  .salary-v5-actions{display:grid!important;grid-template-columns:1fr!important}
  .salary-v5-btn{width:100%!important}
}

/* ============================================================
   СОТРУДНИКИ
   ============================================================ */
.employees-table{overflow:auto!important}
.employees-table table{min-width:920px!important}
.employee-name-cell small{display:none!important}
.employee-name-cell strong{display:block!important;font-weight:800!important;line-height:1.25!important}
.employee-actions{
  display:grid!important;
  grid-template-columns:1fr!important;
  gap:8px!important;
  align-items:stretch!important;
  min-width:150px!important;
}
.employee-actions .btn{
  width:100%!important;
  justify-content:center!important;
  min-height:34px!important;
  margin:0!important;
  border-radius:10px!important;
  padding:7px 10px!important;
  font-size:12px!important;
}

/* ============================================================
   МОДАЛКИ: без рывков, без вылезаний
   ============================================================ */
html.modal-is-open,
body.modal-is-open{overflow:hidden!important}
.modal-backdrop,
.salary-v5-modal-backdrop{
  position:fixed!important;
  inset:0!important;
  z-index:250000!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  padding:22px!important;
  overflow:auto!important;
  background:rgba(15,23,42,.42)!important;
  backdrop-filter:blur(10px)!important;
}
.modal,
.salary-v5-modal,
.modal-card{
  width:min(780px,100%)!important;
  max-width:100%!important;
  max-height:min(88vh,900px)!important;
  overflow:auto!important;
  margin:auto!important;
  transform:none!important;
  border-radius:22px!important;
}
.modal-head,
.salary-v5-modal__head{
  position:sticky!important;
  top:0!important;
  z-index:3!important;
  background:#fff!important;
  border-bottom:1px solid var(--v11-line)!important;
}
.modal form,
.modal .form-grid,
.modal-body,
.salary-v5-modal__body{padding:18px!important}
.form-grid{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:14px!important}
.form-grid .full{grid-column:1/-1!important}
@media(max-width:640px){
  .modal-backdrop,.salary-v5-modal-backdrop{align-items:flex-end!important;padding:10px!important}
  .modal,.salary-v5-modal,.modal-card{max-height:92vh!important;border-radius:20px 20px 0 0!important}
  .form-grid{grid-template-columns:1fr!important}
}

/* ============================================================
   КАБИНЕТ СОТРУДНИКА И ОБЩАЯ АДАПТАЦИЯ
   ============================================================ */
.salary-table table,
.table-wrap table{min-width:720px}
.mini-row{min-width:0!important;overflow:hidden!important;gap:12px!important}
.mini-row > div:first-child{min-width:0!important;display:flex!important;flex-direction:column!important;gap:3px!important}
.mini-row strong,.mini-row span{overflow:hidden!important;text-overflow:ellipsis!important}
.profile-list strong{word-break:break-word!important}

@media(max-width:1080px){
  .main{max-width:none!important;padding-left:20px!important;padding-right:20px!important}
  #pageContent{width:100%!important}
  .grid-4{grid-template-columns:repeat(2,minmax(0,1fr))!important}
  .grid-3{grid-template-columns:repeat(2,minmax(0,1fr))!important}
}
@media(max-width:860px){
  .main{padding:0 16px 104px!important;max-width:none!important}
  .topbar{padding-top:18px!important}
  .mobile-menu-btn{display:inline-flex!important}
}
@media(max-width:560px){
  .grid-4,.grid-3,.grid-2{grid-template-columns:1fr!important}
  .card{padding:16px!important;border-radius:20px!important}
  .toolbar,.toolbar-compact{display:grid!important;grid-template-columns:1fr!important;gap:12px!important}
  .toolbar .btn,.toolbar-compact .btn{width:100%!important}
}
