/* ============================================================
   rekrut — ДЕСКТОП-ВЕРСИЯ (>=1024px)
   Подключается через <link media="(min-width:1024px)"> ПОСЛЕ
   встроенного <style> — порядок источника load-bearing:
   многие переопределения выигрывают только за счёт него.
   Мобильные стили этот файл не трогает вообще.
   ============================================================ */
@media (min-width:1024px){

/* ============ 1. ОБОЛОЧКА: ТАБ-БАР -> САЙДБАР ============ */
:root{--tabbar-h:0px} /* разом зануляет отступы .screen, #toastRoot, .fab */
body{display:block}
.app{width:100%;max-width:none;flex-direction:row;border-left:none;border-right:none}
main{flex:1;min-width:0}

.tabbar{
  position:static;order:-1;width:240px;height:auto;flex:none;
  flex-direction:column;align-items:stretch;justify-content:flex-start;gap:4px;
  padding:20px 12px 24px;border-top:none;border-right:1px solid var(--line);
  background:rgba(18,18,20,.85);
}
.tabbar::before{
  content:"rekrut";display:block;font-size:24px;font-weight:800;
  letter-spacing:-.03em;color:var(--text);padding:6px 12px 22px;
}
.tab{
  flex:0 0 auto;flex-direction:row;justify-content:flex-start;gap:12px;
  padding:11px 12px;border-radius:var(--r-sm);font-size:14px;font-weight:500;
  color:var(--text-2);
}
.tab svg.ic{width:20px;height:20px}
.tab--active,.tab--active:hover{background:var(--green-dim);color:var(--green);font-weight:600}

/* оверлей открыт -> сайдбар приглушён и некликабелен
   (Router.go не закрывает оверлеи; на мобильном таб-бар перекрыт геометрически) */
.app:has(.screen--overlay.active) .tabbar{pointer-events:none;opacity:.5}
.tabbar{transition:opacity .2s ease}

/* контент-колонка 1140px по центру (padding-% считается от main, без сайдбара) */
.screen{padding:32px max(40px,calc((100% - 1140px)/2)) 56px}

/* FAB: только позиция — display управляется JS инлайном, не трогаем */
.fab{right:32px;bottom:32px}

/* тосты — справа снизу; max-width в px обязателен (88% самоссылочны при shrink-to-fit) */
#toastRoot{left:auto;right:28px;bottom:28px;align-items:flex-end}
.toast{max-width:380px}

/* ============ 2. ГОЛОВНА — ДАШБОРД-ГРИД ПО ПАНЕЛЯМ ============ */
/* Структура: section > header.home-head + #hpanels > .hpanel[data-panel] > .hpanel-in > карточка.
   Спаны по data-panel — не зависят от порядка панелей (пользователь их переставляет). */
[data-screen="home"]>.home-head{padding:14px 0 20px}
#hpanels{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:14px;align-content:start}
#hpanels .hpanel{margin-bottom:0}
#hpanels [data-panel="gami"]{grid-column:span 7}
#hpanels [data-panel="day"]{grid-column:span 5}
#hpanels [data-panel="hero"]{grid-column:span 4}
#hpanels [data-panel="stats"]{grid-column:span 8}
#hpanels [data-panel="chart1"],
#hpanels [data-panel="chart2"]{grid-column:span 6}
#hpanels [data-panel="quick"]{grid-column:1/-1}
/* соседние панели одного ряда — одинаковой высоты */
#hpanels .hpanel{display:flex;flex-direction:column}
#hpanels .hpanel-in{flex:1;display:flex;flex-direction:column}
#hpanels .hpanel-in>.card,
#hpanels .hpanel-in>.stats4{flex:1}
#hpanels .stats4{gap:14px}
#hpanels [data-panel="quick"] .section-title{margin-top:4px}

/* РЕЖИМ РЕДАКТИРОВАНИЯ: сетка сохраняется — HomeDrag в 2D-режиме (updateGrid:
   hit-test панели под курсором + живой insertBefore). Курсоры — affordance drag'a. */
#hpanels.home-edit .hpanel{cursor:grab}
#hpanels.home-edit .hpanel--drag{cursor:grabbing}

.quick-tile{flex-direction:row;justify-content:flex-start;gap:12px;padding:14px 16px}
.quick-tile>span:last-child{font-size:13px;text-align:left}
.stat{padding:16px 8px}

/* SVG-графики: viewBox 300x130/110 при width:100% распухает на широкой карточке;
   preserveAspectRatio из CSS недоступен -> фикс. высота, пропорц. ширина, центр */
[data-screen="home"] svg.chart{width:auto;max-width:100%;height:176px;margin:8px auto 0;display:block}

/* ============ 3. ВАКАНСІЇ / КАНДИДАТИ — ГРИДЫ КАРТОЧЕК ============ */
#vlist{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:14px}
#vlist .vcard{margin-bottom:0}
#clist{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:12px}
#clist .ccard{margin-bottom:0}
.empty{grid-column:1/-1;padding:80px 0}
.searchbar{max-width:440px}
.chips{flex-wrap:wrap;overflow:visible;row-gap:8px} /* скролл -> перенос; JS ничего не измеряет */

/* ============ 4. ЗАДАЧІ / ПОСТИ — ГРИД НА #tbody ============ */
#tbody{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:12px;align-content:start}
#tbody>.chips,
#tbody>#tlist,
#tbody>.empty{grid-column:1/-1}
#tbody>.post-card{margin-bottom:0}
#tlist{max-width:720px} /* задачи — одна читабельная колонка */
[data-screen="tasks"]>.seg{max-width:380px}
.post-img{height:180px}
/* .seg-i НЕ трогаем: JS пишет инлайн transform */

/* ============ 4b. ВАКАНСІЇ — БЫСТРЫЕ ДЕЙСТВИЯ НА ХОВЕРЕ ============ */
/* пауза/редактирование без похода в кебаб-меню; на мобильном .vquick скрыт */
.vquick{display:flex;gap:6px;opacity:0;transition:opacity .15s ease}
.vcard:hover .vquick,.vcard:focus-within .vquick{opacity:1}
.vq{width:34px;height:34px;border-radius:9px;background:var(--card-2);display:grid;place-items:center;color:var(--text-2);flex:none}
.vq:hover{background:#3a3a3c;color:var(--text)}
.vq svg.ic{width:16px;height:16px}

/* ============ 5. БІЛЬШЕ / МІСТА / ДОСЯГНЕННЯ ============ */
[data-screen="more"]>*{max-width:640px;margin-inline:auto}
.city-grid{grid-template-columns:repeat(6,1fr)} /* популярных ровно 6 — без сироты */
[data-screen="cityPicker"]>*{max-width:1100px;margin-inline:auto}
/* большое пространство: «Усі міста» — сетка карточек вместо тощего списка */
#cityBody{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px 12px}
#cityBody>.section-title,#cityBody>.city-grid,#cityBody>form,#cityBody>.empty,
#cityBody>.list-row.row-green{grid-column:1/-1}
#cityBody>.list-row{background:var(--card);border-radius:var(--r-md);border-bottom:none;padding:12px 16px}
#cityBody>button.list-row:hover{background:#232326;box-shadow:0 0 0 1px rgba(48,209,88,.14)}
#cityBody .city-thumb{width:46px;height:46px;border-radius:12px}
.city-grid .city-tile{height:130px;font-size:14px}
#cityBody>form.card{max-width:520px}
.ach-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
[data-screen="achievements"]>*{max-width:1000px;margin-inline:auto}

/* ============ 6. ПРОФІЛЬ КАНДИДАТА — ДВЕ КОЛОНКИ ============ */
/* Ровно 12 прямых детей в фикс. порядке; section-title — дети 4/6/8/10.
   Селекторы class-qualified: fallback «не знайдено» деградирует безопасно. */
[data-screen="candidateProfile"].active{
  display:grid;grid-template-columns:minmax(280px,340px) minmax(0,1fr);
  gap:14px 36px;align-content:start;
  padding-inline:max(48px,calc((100% - 980px)/2));
}
[data-screen="candidateProfile"]>.screen-head{grid-column:1/-1;grid-row:1}
[data-screen="candidateProfile"]>.profile-id{
  grid-column:1;grid-row:2/span 2;align-self:start;
  background:var(--card);border-radius:var(--r-lg);padding:28px 20px 24px;
}
[data-screen="candidateProfile"]>.cact-row{grid-column:1;grid-row:4;align-self:start}
[data-screen="candidateProfile"]>.profile-cta{grid-column:1;grid-row:5;align-self:start;margin-top:8px}
[data-screen="candidateProfile"]>.section-title{margin:0 4px}
[data-screen="candidateProfile"]>.section-title:nth-child(4){grid-column:2;grid-row:2;align-self:end}
[data-screen="candidateProfile"]>.card.group:nth-child(5){grid-column:2;grid-row:3}
[data-screen="candidateProfile"]>.section-title:nth-child(6){grid-column:2;grid-row:4;align-self:end}
[data-screen="candidateProfile"]>.note-card{grid-column:2;grid-row:5}
[data-screen="candidateProfile"]>.section-title:nth-child(8){grid-column:2;grid-row:6;align-self:end}
[data-screen="candidateProfile"]>.card.group:nth-child(9){grid-column:2;grid-row:7}
[data-screen="candidateProfile"]>.section-title:nth-child(10){grid-column:2;grid-row:8;align-self:end}
[data-screen="candidateProfile"]>.card.tl{grid-column:2;grid-row:9}

/* ============ 7. ДЕТАЛІ ВАКАНСІЇ — SPAN-СТРАТЕГИЯ ============ */
/* всё на всю ширину, кроме .ccard — они авто-флоят 2-up при любом N */
[data-screen="vacancyDetail"].active{
  display:grid;grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px 14px;align-content:start;
  padding-inline:max(48px,calc((100% - 900px)/2));
}
[data-screen="vacancyDetail"]>.screen-head,
[data-screen="vacancyDetail"]>.profile-id,
[data-screen="vacancyDetail"]>.section-title,
[data-screen="vacancyDetail"]>.card:not(.ccard){grid-column:1/-1}
[data-screen="vacancyDetail"]>.section-title{margin:10px 4px 0}
[data-screen="vacancyDetail"]>.ccard{margin-bottom:0}
[data-screen="vacancyDetail"]>.card.group{margin-top:0!important} /* инлайн style="margin-top:10px" */
/* шапка-лента вместо центрированной идентичности */
[data-screen="vacancyDetail"]>.profile-id{flex-direction:row;align-items:center;gap:18px;text-align:left;padding:6px 0 12px}
[data-screen="vacancyDetail"]>.profile-id h2{margin-top:0}
[data-screen="vacancyDetail"]>.profile-id .badge{margin-top:0}

/* ============ 8. BOTTOM-SHEET -> ЦЕНТРИРОВАННАЯ МОДАЛКА ============ */
/* Открытие — мобильное .sheet-wrap.open .sheet{transform:none} (0,2,0 — выигрывает само),
   поэтому центрируем независимым свойством translate, не transform.
   JS удаляет узел через 300мс -> анимации <= .3s. */
.sheet-backdrop{background:rgba(0,0,0,.6);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.sheet{
  left:50%;top:50%;right:auto;bottom:auto;translate:-50% -50%;
  width:min(520px,calc(100vw - 48px));max-height:min(78vh,720px);
  border-radius:20px;padding:26px 28px 28px;
  transform:translateY(16px) scale(.95);opacity:0; /* закрытое состояние */
  box-shadow:0 0 0 1px rgba(255,255,255,.06),0 32px 80px rgba(0,0,0,.65);
  transition:transform .28s cubic-bezier(.32,.72,.27,1),opacity .22s ease; /* opacity обязательна */
}
.sheet-wrap.open .sheet{opacity:1}
.sheet-handle{display:none}
.sheet-title{font-size:20px;margin:0 0 18px}

/* ============ 9. FAB -> PILL-КНОПКА С ПОДПИСЬЮ ============ */
/* JS ставит инлайн display:grid — работаем с гридом, не против него */
.fab{
  width:auto;height:52px;border-radius:999px;
  grid-auto-flow:column;column-gap:9px;align-items:center;
  padding:0 24px 0 18px;
  box-shadow:0 10px 28px rgba(48,209,88,.3),0 10px 28px rgba(0,0,0,.45);
}
.fab svg{width:20px;height:20px}
.fab::after{content:"Додати кандидата";font-size:14.5px;font-weight:700;white-space:nowrap;letter-spacing:.01em}

/* ============ 10. HOVER / MOTION ============ */
/* мастер-список transition: передекларирован ПОСЛЕ мобильного — выигрывает по порядку;
   .star-btn/.kebab/.cact добавлены (их нет в мобильном списке) */
.chip,.quick-tile,.stat,.icon-btn,.fab,.menu-row,.list-row,.city-tile,.task-row,.btn,.hero-btn,.tab,
.vcard,.ccard,.note-card,.pp-photo,.post-card,.seg-btn,.cact,.star-btn,.kebab{
  transition:transform .16s ease,background-color .18s ease,color .18s ease,
             box-shadow .25s ease,filter .2s ease,opacity .2s ease;
}
.city-img{transition:transform .35s cubic-bezier(.3,.7,.3,1)}
.quick-tile .qi{transition:background-color .2s ease,filter .2s ease}

@media (hover:hover) and (pointer:fine){

  /* .btn — классический shine sweep (псевдо свободен: единственный псевдо в коде — .city-tile::after) */
  .btn{position:relative;overflow:hidden}
  .btn:not(.btn--muted):not(.btn--restore):not(.btn--done)::before{
    content:"";position:absolute;inset:0;pointer-events:none;
    background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.25) 50%,transparent 60%);
    transform:translateX(-150%);transition:transform .6s ease;
  }
  .btn:not(.btn--muted):not(.btn--restore):not(.btn--done):hover::before{transform:translateX(150%)}
  .btn:hover{transform:translateY(-1px)}
  .btn:not(.btn--muted):not(.btn--restore):not(.btn--done):hover{
    box-shadow:0 8px 22px rgba(48,209,88,.32);filter:brightness(1.05);
  }
  .btn--muted:hover,.btn--restore:hover{background:#3a3a3c}
  .btn--done:hover{background:rgba(48,209,88,.22)}

  /* FAB: только brightness/тень — ::after занят подписью, shine не вешать */
  .fab:hover{transform:translateY(-2px);filter:brightness(1.07);
    box-shadow:0 16px 36px rgba(48,209,88,.4),0 14px 32px rgba(0,0,0,.5)}

  /* чипы */
  .chip:hover{background:var(--card-2);color:var(--text)}
  .chip--active:hover{background:rgba(48,209,88,.24);color:var(--green)}
  .city-chip:hover{background:var(--card-2);color:var(--text)}

  /* кнопки-иконки */
  .icon-btn:hover{background:var(--card-2)}
  .icon-btn--green:hover{background:var(--green);filter:brightness(1.12);box-shadow:0 6px 18px rgba(48,209,88,.38)}
  .hero-btn:hover{background:rgba(48,209,88,.26);transform:translateY(-1px)}

  /* плитки и статы */
  .quick-tile:hover,.stat:hover{transform:translateY(-2px);background:#232326;
    box-shadow:0 0 0 1px rgba(255,255,255,.06),0 12px 28px rgba(0,0,0,.42)}
  .quick-tile:hover .qi{background:#3a3a3c}
  .quick-tile:hover .qi--green{background:var(--green);filter:brightness(1.08)}

  /* сайдбар */
  .tab:hover{background:rgba(255,255,255,.06);color:var(--text)}
  .tab--active:hover{background:var(--green-dim);color:var(--green)}

  /* строки списков/меню: hover-фон с «воздухом», текст не смещается */
  .list-row{margin-inline:-10px;width:calc(100% + 20px);padding-left:12px;padding-right:12px;border-radius:10px}
  .menu-row{margin-inline:-10px;width:calc(100% + 20px);padding-left:14px;padding-right:14px;border-radius:10px}
  button.list-row:hover,a.list-row:hover,.menu-row:hover{background:rgba(255,255,255,.05)}
  .menu-row--danger:hover{background:rgba(255,69,58,.1)}

  /* карточки: lift + зелёное кольцо тенью (у .card border:none — ноль layout-shift) */
  .vcard:hover,.ccard:hover,.post-card:hover,.task-row:hover{
    transform:translateY(-2px);background:#232326;
    box-shadow:0 0 0 1px rgba(48,209,88,.16),0 16px 36px rgba(0,0,0,.5);
  }
  .vcard--closed:hover{opacity:.75}
  .note-card:hover{background:#232326}

  /* мелкие интерактивы */
  .star-btn:hover,.kebab:hover{color:var(--text);transform:scale(1.12)}
  .star-btn.is-fav:hover{color:#ffd60a;filter:brightness(1.12)}
  .seg-btn:hover{color:var(--text)}
  .cact:hover{background:var(--card-2);transform:translateY(-2px)}
  .ach:hover{transform:translateY(-2px)}
  .city-tile:hover{box-shadow:0 12px 28px rgba(0,0,0,.5)}
  .city-tile:hover .city-img{transform:scale(1.07)}
  .searchbar:hover{border-color:rgba(255,255,255,.12)}
  .searchbar:focus-within:hover{border-color:var(--green)} /* ре-декларация обязательна */

  /* :active ПОСЛЕ hover — та же специфичность, решает порядок */
  .vcard:active,.ccard:active,.post-card:active,.task-row:active{transform:translateY(-1px) scale(.99)}
  .quick-tile:active,.stat:active{transform:translateY(0) scale(.98)}
  .fab:active{transform:translateY(0) scale(.97)}
  .tab:active{transform:scale(.98)}
  button.list-row:active,a.list-row:active,.menu-row:active{transform:scale(.99)}

}/* конец (hover:hover) */

/* ============ 11. СКРОЛЛБАРЫ / ФОКУС / ТИПОГРАФИКА ============ */
.screen,.sheet{
  scrollbar-width:thin;
  scrollbar-color:rgba(255,255,255,.18) transparent;
}
/* для старых Safari; Chrome>=121 игнорирует webkit-псевдо при scrollbar-width — намеренно */
.screen::-webkit-scrollbar,.sheet::-webkit-scrollbar{display:block;width:10px}
.screen::-webkit-scrollbar-track,.sheet::-webkit-scrollbar-track{background:transparent}
.screen::-webkit-scrollbar-thumb,.sheet::-webkit-scrollbar-thumb{
  background:rgba(255,255,255,.16);border-radius:99px;
  border:3px solid transparent;background-clip:padding-box;
}

:focus-visible{outline:2px solid var(--green);outline-offset:2px}
.field input:focus-visible,.field select:focus-visible,.field textarea:focus-visible,
.searchbar input:focus-visible{outline:none} /* фокус уже виден через border-color */
::selection{background:rgba(48,209,88,.35);color:#fff}

/* типографика — сдержанно; инлайн h1 оверлеев и размеры аватаров не трогаем */
.screen-head h1{font-size:30px}
.hello b{font-size:22px}
.hero-num{font-size:56px}
.chart-num{font-size:34px}
.day-row b{font-size:20px}
.stat b{font-size:20px}
.profile-id h2{font-size:26px}

@media (prefers-reduced-motion:reduce){
  .sheet,.city-img,.btn::before{transition-duration:.01ms}
}

/* ============ 12. ШИРОКИЕ ЭКРАНЫ >=1440px ============ */
@media (min-width:1440px){
  .tabbar{width:264px}
  .screen{padding-inline:max(64px,calc((100% - 1280px)/2))}
  #hpanels{gap:16px}
  [data-screen="home"] svg.chart{height:200px}
  #vlist{grid-template-columns:repeat(auto-fill,minmax(380px,1fr))}
  #clist{grid-template-columns:repeat(auto-fill,minmax(360px,1fr))}
}

}/* конец @media (min-width:1024px) */
