/* ===== AP-R · Попап «Все города Юга» (открывается с плитки +5) =====
   Namespace cpx-* — полностью изолирован от CSS главной. Не содержит глобальных ресетов. */

.cpx-overlay,
.cpx-overlay *{box-sizing:border-box;}
.cpx-overlay{
  position:fixed; inset:0; z-index:1000; display:flex; align-items:center; justify-content:center;
  padding:20px; opacity:0; visibility:hidden;
  transition:opacity .25s ease, visibility .25s ease;
  font-family:inherit;
}
.cpx-overlay.cpx-open{opacity:1; visibility:visible;}
.cpx-backdrop{
  position:absolute; inset:0; background:rgba(10,34,55,.55);
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
}

/* ----- окно ----- */
.cpx-modal{
  position:relative; z-index:1; width:min(1040px,100%); max-height:88vh;
  background:#fff; border-radius:20px; overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.35);
  display:grid; grid-template-columns:32% 68%;
  transform:translateY(20px) scale(.96); opacity:0;
  transition:transform .25s cubic-bezier(.4,0,.2,1), opacity .25s cubic-bezier(.4,0,.2,1);
}
.cpx-overlay.cpx-open .cpx-modal{transform:translateY(0) scale(1); opacity:1;}

/* ----- левая navy-панель ----- */
.cpx-panel{
  position:relative; color:#fff; padding:34px 30px 30px;
  display:flex; flex-direction:column; overflow:hidden;
  background:
    radial-gradient(120% 80% at 18% 8%, rgba(23,183,191,.28), transparent 56%),
    radial-gradient(90% 70% at 90% 100%, rgba(23,183,191,.12), transparent 60%),
    linear-gradient(160deg,#13374f 0%,#0f2a3d 60%,#0a2237 100%);
}
.cpx-panel::after{
  content:""; position:absolute; right:-60px; top:-60px; width:220px; height:220px;
  background:radial-gradient(circle, rgba(23,183,191,.35), transparent 70%);
  filter:blur(6px); pointer-events:none;
}
.cpx-panel-eyebrow{
  font-size:11px; font-weight:700; letter-spacing:.16em; text-transform:uppercase;
  color:#17b7bf; margin-bottom:14px; display:flex; align-items:center; gap:8px;
}
.cpx-panel-eyebrow svg{width:15px; height:15px; flex:none;}
.cpx-panel-title{
  font-size:clamp(22px,2.4vw,29px); font-weight:700; letter-spacing:-.012em;
  line-height:1.12; color:#fff; margin:0;
}
.cpx-panel-title b{color:#a3d977; font-weight:700;}
.cpx-metrics{margin-top:26px; display:flex; flex-direction:column; gap:18px;}
.cpx-metric{display:flex; align-items:flex-start; gap:13px;}
.cpx-mic{
  width:40px; height:40px; border-radius:11px; flex:none; display:grid; place-items:center;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.12);
}
.cpx-mic svg{width:20px; height:20px; stroke:#17b7bf; fill:none;}
.cpx-mnum{font-size:23px; font-weight:700; line-height:1; letter-spacing:-.01em;}
.cpx-mnum .cpx-accent{color:#a3d977;}
.cpx-mlbl{font-size:12.5px; color:rgba(255,255,255,.66); margin-top:5px; line-height:1.35;}
.cpx-mtag{display:none;}

/* поиск */
.cpx-search{margin-top:26px; position:relative;}
.cpx-search > svg{
  position:absolute; left:15px; top:50%; transform:translateY(-50%);
  width:18px; height:18px; stroke:rgba(255,255,255,.55); fill:none; pointer-events:none;
}
.cpx-search input{
  width:100%; height:46px; border-radius:12px; border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.06); color:#fff; font-size:15px;
  padding:0 40px 0 44px; outline:none; font-family:inherit;
  transition:border-color .18s, background .18s, box-shadow .18s;
}
.cpx-search input::placeholder{color:rgba(255,255,255,.5);}
.cpx-search input:focus{
  border-color:#17b7bf; background:rgba(255,255,255,.1);
  box-shadow:0 0 0 3px rgba(23,183,191,.25);
}
.cpx-clear{
  position:absolute; right:9px; top:50%; transform:translateY(-50%);
  width:26px; height:26px; border-radius:50%; border:none; cursor:pointer;
  background:rgba(255,255,255,.12); color:#fff; font-size:15px; line-height:1;
  display:none; align-items:center; justify-content:center; transition:background .15s;
}
.cpx-clear:hover{background:rgba(255,255,255,.22);}
.cpx-search.cpx-has-value .cpx-clear{display:flex;}

.cpx-panel-foot{
  margin-top:auto; padding-top:24px; display:flex; align-items:flex-start; gap:9px;
  font-size:12px; line-height:1.45; color:rgba(255,255,255,.58);
}
.cpx-panel-foot svg{width:15px; height:15px; flex:none; margin-top:1px; stroke:#17b7bf; fill:none;}

/* ----- правая светлая зона ----- */
.cpx-content{position:relative; background:#fafafa; display:flex; flex-direction:column; min-width:0; max-height:88vh;}
.cpx-close{
  position:absolute; top:16px; right:16px; z-index:7;
  width:38px; height:38px; border-radius:50%; border:none; cursor:pointer;
  background:#fff; color:#13374f; font-size:24px; font-weight:400; line-height:1;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 16px rgba(10,34,55,.30), 0 0 0 1px rgba(10,34,55,.06);
  transition:background .15s, transform .15s, color .15s, box-shadow .15s;
}
.cpx-close:hover{background:#13374f; color:#fff; transform:rotate(90deg); box-shadow:0 6px 20px rgba(10,34,55,.4);}
.cpx-close:focus-visible{outline:3px solid rgba(23,183,191,.6); outline-offset:2px;}

.cpx-content-head{padding:24px 28px 18px; flex:none;}
.cpx-content-head h3{
  font-size:20px; font-weight:700; color:#13374f; letter-spacing:-.01em; line-height:1.2;
  padding-right:44px; margin:0;
}
.cpx-ch-sub{margin-top:6px; font-size:13.5px; color:#3a4754;}
.cpx-ch-sub b{color:#13374f; font-weight:700;}

.cpx-scroll{
  flex:1; overflow-y:auto; padding:4px 28px 28px;
  scrollbar-width:thin; scrollbar-color:#c8d2da transparent;
}
.cpx-scroll::-webkit-scrollbar{width:9px;}
.cpx-scroll::-webkit-scrollbar-thumb{background:#c8d2da; border-radius:8px; border:2px solid #fafafa;}
.cpx-scroll::-webkit-scrollbar-track{background:transparent;}

.cpx-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:14px;}

/* ----- плитка города ----- */
.cpx-city{
  position:relative; display:block; text-decoration:none; color:#fff;
  aspect-ratio:5/6; border-radius:14px; overflow:hidden;
  box-shadow:0 1px 2px rgba(19,55,79,.04), 0 8px 24px rgba(19,55,79,.06); isolation:isolate;
  transition:transform .22s cubic-bezier(.4,0,.2,1), box-shadow .22s;
}
.cpx-city:hover{transform:translateY(-4px); box-shadow:0 8px 24px rgba(19,55,79,.08), 0 24px 48px rgba(19,55,79,.10);}
.cpx-city:focus-visible{outline:3px solid #17b7bf; outline-offset:2px;}
.cpx-ph{position:absolute; inset:0; z-index:0;}
.cpx-city img{
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .5s cubic-bezier(.2,0,.2,1);
}
.cpx-city:hover img{transform:scale(1.06);}
.cpx-grad{
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, transparent 42%, rgba(10,34,55,.92));
}
.cpx-body{position:absolute; left:0; right:0; bottom:0; z-index:2; padding:14px 14px 13px;}
.cpx-cname{
  font-size:17px; font-weight:700; line-height:1.16; letter-spacing:-.01em;
  text-shadow:0 1px 4px rgba(0,0,0,.3);
}
.cpx-meta{margin-top:8px; display:flex; align-items:baseline; justify-content:space-between; gap:8px;}
.cpx-cnt{
  font-size:12px; font-weight:600; color:rgba(255,255,255,.82);
  background:rgba(255,255,255,.14); padding:3px 8px; border-radius:999px;
  -webkit-backdrop-filter:blur(2px); backdrop-filter:blur(2px); white-space:nowrap;
}
.cpx-price{font-size:13px; font-weight:700; color:#fff; white-space:nowrap;}
.cpx-arrow{
  position:absolute; top:11px; right:11px; z-index:3;
  width:30px; height:30px; border-radius:50%; background:#fff;
  display:grid; place-items:center;
  opacity:0; transform:translateY(-4px) scale(.85);
  transition:opacity .22s, transform .22s;
}
.cpx-arrow svg{width:15px; height:15px; stroke:#13374f; fill:none;}
.cpx-city:hover .cpx-arrow,
.cpx-city:focus-visible .cpx-arrow{opacity:1; transform:translateY(0) scale(1);}
.cpx-soon{
  position:absolute; top:11px; left:11px; z-index:3;
  font-size:10.5px; font-weight:700; letter-spacing:.04em; color:#fff;
  background:rgba(255,255,255,.16); border:1px solid rgba(255,255,255,.28);
  -webkit-backdrop-filter:blur(3px); backdrop-filter:blur(3px);
  padding:3px 9px; border-radius:999px;
}
.cpx-sky{position:absolute; left:0; right:0; bottom:0; z-index:0; height:55%; width:100%; fill:rgba(255,255,255,.18);}
.cpx-hl{background:rgba(163,217,119,.42); border-radius:3px; padding:0 1px;}

/* ничего не найдено */
.cpx-empty{
  display:none; flex-direction:column; align-items:center; text-align:center;
  padding:46px 20px 38px; color:#6c7785;
}
.cpx-empty.cpx-show{display:flex;}
.cpx-empty > svg{width:46px; height:46px; stroke:#c2ccd5; fill:none; margin-bottom:14px;}
.cpx-empty b{font-size:16px; color:#1a2330; font-weight:700;}
.cpx-empty p{margin-top:6px; font-size:13.5px; max-width:280px; line-height:1.45;}
.cpx-reset{
  margin-top:16px; border:1px solid #e6e8ec; background:#fff; color:#13374f;
  font-weight:600; font-size:13px; padding:9px 16px; border-radius:999px; cursor:pointer;
  transition:border-color .15s, color .15s; font-family:inherit;
}
.cpx-reset:hover{border-color:#17b7bf; color:#17b7bf;}

/* ----- адаптив ----- */
@media (max-width:900px){
  /* модалка стопкой: navy-панель сверху (естественная высота), контент со своим скроллом */
  .cpx-modal{display:flex; flex-direction:column; grid-template-columns:none; max-height:92vh;}
  .cpx-panel{flex:none; padding:22px 22px 20px;}
  .cpx-panel::after{width:160px; height:160px;}
  .cpx-panel-eyebrow{margin-bottom:10px;}
  .cpx-panel-title{font-size:21px;}
  .cpx-metrics{margin-top:15px; flex-direction:row; flex-wrap:wrap; gap:12px 22px;}
  .cpx-metric{gap:10px;}
  .cpx-mic{width:32px; height:32px;}
  .cpx-mnum{font-size:18px;}
  .cpx-mlbl{font-size:11px;}
  .cpx-search{margin-top:15px;}
  .cpx-panel-foot{display:none;}
  .cpx-content{flex:1 1 auto; min-height:0; max-height:none; position:static;}
  .cpx-content-head{padding:15px 22px 11px;}
  .cpx-grid{grid-template-columns:repeat(2,1fr);}
  /* крестик — в самый правый верхний угол модалки (поверх navy-шапки): солидный белый круг, заметный */
  .cpx-close{top:14px; right:14px;}
}
@media (max-width:520px){
  .cpx-overlay{padding:0;}
  .cpx-modal{width:100%; max-height:100vh; height:100vh; border-radius:0; display:flex; flex-direction:column;}
  /* сжатая navy-шапка: без eyebrow, метрики — одной строкой */
  .cpx-panel{padding:16px 16px 13px;}
  .cpx-panel::after{width:130px; height:130px;}
  .cpx-panel-eyebrow{display:none;}
  .cpx-panel-title{font-size:18px; line-height:1.16;}
  .cpx-metrics{margin-top:9px; flex-direction:row; flex-wrap:wrap; gap:3px 14px; align-items:baseline;}
  .cpx-metric{flex-direction:row; gap:5px; align-items:baseline;}
  .cpx-mic{display:none;}
  .cpx-mlbl{display:none;}
  .cpx-mnum{font-size:14px;}
  .cpx-mnum .cpx-mtag{display:inline; font-size:10.5px; font-weight:600; color:rgba(255,255,255,.55); margin-left:3px; letter-spacing:0;}
  .cpx-search{margin-top:11px;}
  .cpx-search input{height:42px;}
  /* белая шапка без дубля «Выберите город» — только живой счётчик */
  .cpx-content-head{padding:9px 16px 7px;}
  .cpx-content-head h3{display:none;}
  .cpx-ch-sub{margin-top:0; font-size:12px;}
  .cpx-scroll{padding:7px 16px 18px;}
  .cpx-grid{grid-template-columns:1fr; gap:12px;}
  .cpx-city{aspect-ratio:16/9;}
  .cpx-cname{font-size:18px;}
  .cpx-close{top:13px; right:13px;}
}
@media (prefers-reduced-motion:reduce){
  .cpx-overlay, .cpx-overlay *{transition:none!important; animation:none!important;}
}
