
/* ============================================================
   v57: bottom nav sealed to bottom + modal form layout fix
   ============================================================ */

:root{
  --pvz-v57-vh:100dvh;
  --pvz-v57-top:0px;
  --pvz-bottom-real-h:92px;
}

/* ---------- Bottom mobile menu: закрываем всю нижнюю область, без отрыва ---------- */
@media(max-width:860px){
  body{
    overflow-x:hidden!important;
  }

  .mobile-bottom,
  .mobile-bottom.is-pwa-fixed{
    display:grid!important;
    grid-template-columns:repeat(4,minmax(0,1fr))!important;
    position:fixed!important;
    left:0!important;
    right:0!important;
    top:auto!important;
    bottom:0!important;
    width:100vw!important;
    max-width:100vw!important;
    min-height:calc(78px + env(safe-area-inset-bottom, 0px))!important;
    height:auto!important;
    margin:0!important;
    padding:7px 8px calc(10px + env(safe-area-inset-bottom, 0px))!important;
    z-index:2147483000!important;
    transform:translate3d(0,0,0)!important;
    -webkit-transform:translate3d(0,0,0)!important;
    background:rgba(255,255,255,.99)!important;
    border-top:1px solid rgba(219,229,242,.95)!important;
    box-shadow:0 -12px 34px rgba(15,23,42,.10)!important;
    -webkit-backdrop-filter:saturate(160%) blur(18px)!important;
    backdrop-filter:saturate(160%) blur(18px)!important;
    contain:layout paint style!important;
  }

  /* Белая подложка ниже меню: если iOS отдаёт странную safe-area, контент не будет виден под меню */
  .mobile-bottom::after{
    content:"";
    position:fixed!important;
    left:0!important;
    right:0!important;
    bottom:-80px!important;
    height:82px!important;
    background:rgba(255,255,255,.99)!important;
    pointer-events:none!important;
    z-index:-1!important;
  }

  .mobile-bottom a{
    min-width:0!important;
    min-height:64px!important;
    height:64px!important;
    padding:7px 4px!important;
    border-radius:18px!important;
  }

  .mobile-bottom a.active{
    min-height:64px!important;
    height:64px!important;
  }

  .main{
    padding-bottom:calc(122px + env(safe-area-inset-bottom, 0px))!important;
  }

  body.pvz-select-v50-open .mobile-bottom,
  body.pvz-picker-v50-open .mobile-bottom,
  body.pvz-v57-modal-open .mobile-bottom,
  body.pvz-v56-modal-open .mobile-bottom,
  body.modal-is-open .mobile-bottom,
  body.lock-scroll .mobile-bottom,
  body.pvz-dialog-open .mobile-bottom{
    display:none!important;
  }
}

/* ---------- Modal: fixed viewport, no body-fixed leftovers ---------- */
html.pvz-v57-modal-open,
body.pvz-v57-modal-open{
  overflow:hidden!important;
  overscroll-behavior:none!important;
}

/* Сбрасываем старые фикс-стили, которые могли остаться от v55/v56 */
body:not(.pvz-v57-modal-open):not(.pvz-v56-modal-open):not(.pvz-modal-fixed-open){
  touch-action:auto!important;
}

.modal-backdrop,
.salary-v5-modal-backdrop,
.pvz-modal-backdrop,
.pvz-confirm-backdrop,
.pvz-confirm-overlay,
.confirm-backdrop{
  position:fixed!important;
  left:0!important;
  right:0!important;
  top:var(--pvz-v57-top)!important;
  bottom:auto!important;
  height:var(--pvz-v57-vh)!important;
  min-height:var(--pvz-v57-vh)!important;
  width:100vw!important;
  z-index:900000!important;
  display:flex!important;
  justify-content:center!important;
  align-items:center!important;
  padding:18px!important;
  overflow:hidden!important;
  box-sizing:border-box!important;
  overscroll-behavior:none!important;
  background:rgba(15,23,42,.42)!important;
  -webkit-backdrop-filter:blur(10px)!important;
  backdrop-filter:blur(10px)!important;
}

.modal,
.salary-v5-modal,
.modal-card,
.pvz-modal,
.pvz-confirm,
.confirm-dialog,
dialog[open]{
  width:min(780px, calc(100vw - 36px))!important;
  max-width:calc(100vw - 36px)!important;
  max-height:calc(var(--pvz-v57-vh) - 36px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px))!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  border-radius:26px!important;
  background:#fff!important;
  margin:0!important;
  transform:none!important;
  overscroll-behavior:contain!important;
  box-sizing:border-box!important;
}

.modal-head,
.modal-header,
.salary-v5-modal__head,
.pvz-modal__head,
.pvz-confirm__head{
  flex:0 0 auto!important;
  position:relative!important;
  top:auto!important;
  background:#fff!important;
  z-index:3!important;
  border-bottom:1px solid #e6ebf3!important;
}

/* Внутри окна скроллится только контент */
.modal-body,
.modal-content,
.salary-v5-modal__body,
.pvz-modal__body,
.pvz-confirm__body{
  flex:1 1 auto!important;
  min-height:0!important;
  overflow:auto!important;
  -webkit-overflow-scrolling:touch!important;
  overscroll-behavior:contain!important;
  touch-action:pan-y!important;
  box-sizing:border-box!important;
}

.modal form,
.modal .form-grid,
.modal>.form-grid,
.salary-v5-form-grid{
  min-width:0!important;
  max-width:100%!important;
  box-sizing:border-box!important;
}

/* Ключевой фикс: full-строки реально на всю ширину, не вылезают за рамки */
.salary-v5-form-grid{
  display:grid!important;
  grid-template-columns:repeat(2,minmax(0,1fr))!important;
  gap:14px!important;
}

.salary-v5-form-grid > *,
.salary-v5-field,
.salary-v5-input-wrap,
.salary-v5-input,
.salary-v5-textarea,
.salary-v5-select,
.salary-v5-select__trigger,
.custom-select,
.custom-select__trigger{
  min-width:0!important;
  max-width:100%!important;
  box-sizing:border-box!important;
}

.salary-v5-form-grid > .full,
.salary-v5-form-grid > .salary-v5-field.full,
.salary-v5-form-grid > .salary-v5-field--full{
  grid-column:1 / -1!important;
}

.salary-v5-period-toggle{
  max-width:100%!important;
  box-sizing:border-box!important;
  overflow:hidden!important;
}

.salary-v5-period-toggle span,
.salary-v5-period-toggle strong,
.salary-v5-period-toggle small{
  min-width:0!important;
  overflow-wrap:anywhere!important;
}

/* Кнопки сохраняются отдельным низом, не перекрывают поля */
.salary-v5-modal__actions,
.modal-actions,
.pvz-modal__actions,
.pvz-confirm__actions{
  flex:0 0 auto!important;
  background:#fff!important;
  border-top:1px solid #eef2f7!important;
  padding:12px 20px calc(14px + env(safe-area-inset-bottom, 0px))!important;
  margin:0!important;
  z-index:4!important;
  box-sizing:border-box!important;
}

.salary-v5-modal__actions--fixed{
  position:sticky!important;
  bottom:0!important;
  display:flex!important;
  justify-content:flex-end!important;
  gap:10px!important;
}

.salary-v5-modal__actions .salary-v5-btn{
  min-height:48px!important;
}

/* iOS не должен зумить при фокусе */
.modal input,
.modal textarea,
.modal select,
.salary-v5-modal input,
.salary-v5-modal textarea,
.salary-v5-modal select,
.modal-card input,
.modal-card textarea,
.modal-card select,
.pvz-modal input,
.pvz-modal textarea,
.pvz-modal select{
  font-size:16px!important;
}

@media(max-width:860px){
  .modal-backdrop,
  .salary-v5-modal-backdrop,
  .pvz-modal-backdrop,
  .pvz-confirm-backdrop,
  .pvz-confirm-overlay,
  .confirm-backdrop{
    padding:calc(12px + env(safe-area-inset-top, 0px)) 12px calc(12px + env(safe-area-inset-bottom, 0px))!important;
  }

  .modal,
  .salary-v5-modal,
  .modal-card,
  .pvz-modal,
  .pvz-confirm,
  .confirm-dialog,
  dialog[open]{
    width:calc(100vw - 24px)!important;
    max-width:calc(100vw - 24px)!important;
    max-height:calc(var(--pvz-v57-vh) - 24px - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px))!important;
    border-radius:26px!important;
  }

  .modal-head,
  .salary-v5-modal__head,
  .modal-header{
    padding:18px 18px 14px!important;
  }

  .salary-v5-modal__body,
  .modal-body,
  .modal-content{
    padding:16px!important;
  }

  .salary-v5-form-grid{
    grid-template-columns:1fr!important;
    gap:13px!important;
  }

  .salary-v5-modal__actions{
    padding:12px 16px calc(16px + env(safe-area-inset-bottom, 0px))!important;
  }

  .salary-v5-modal__actions--fixed{
    flex-direction:column!important;
    align-items:stretch!important;
  }

  .salary-v5-modal__actions .salary-v5-btn{
    width:100%!important;
  }
}
