/* Minimal, clean, responsive — светлая тема */
:root{
  --bg:#ffffff;
  --card:#ffffff;
  --card2:#f6f7f9;
  --text:#111827;
  --muted:#6b7280;
  --line:rgba(17,24,39,.12);
  --shadow: 0 10px 30px rgba(17,24,39,.08);
  --r:16px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
a{color:inherit;text-decoration:none}

.container{max-width:1100px;margin:0 auto;padding:0 16px}
.spacer{flex:1}

/* HERO */
.hero{
  min-height: 24vh;
  background-image: var(--hero-bg);
  background-size: cover;
  background-position:center;
  border-bottom:1px solid var(--line);
  color:#fff;
}
.hero__overlay{
  min-height: 24vh;
  background: none; /* градиент убран по запросу */
}
.hero__inner{
  min-height: 24vh;
  display:flex;align-items:flex-end;justify-content:space-between;gap:16px;
  padding: 18px 16px;
}
.hero h1{margin:0;font-size:26px;line-height:1.1}
.hero p{margin:8px 0 0;color:rgba(255,255,255,.86)}
.hero__text{ text-shadow: 0 3px 12px rgba(0,0,0,.45); }

.btn{
  background:rgba(17,24,39,.06);
  color:var(--text);
  border:1px solid var(--line);
  padding:10px 12px;
  border-radius:12px;
  cursor:pointer;
  box-shadow:none;
}
.btn:hover{background:rgba(17,24,39,.10)}
.btn--ghost{background:transparent}


/* Mobile-only: кнопка Фильтры под hero */
.hero-controls{display:none; padding-top:10px;}
.hero-controls .btn{width:auto;}

/* кнопки поверх hero должны быть светлыми */
.hero .btn{
  background:rgba(255,255,255,.14);
  color:#fff;
  border-color:rgba(255,255,255,.22);
}
.hero .btn:hover{background:rgba(255,255,255,.20)}

.icon-btn{
  background:transparent;border:1px solid var(--line);color:var(--text);
  border-radius:12px;padding:8px 10px;cursor:pointer;
}

.layout{display:grid;grid-template-columns:280px 1fr;gap:16px;padding:16px 16px 28px}
.content__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.count{color:var(--muted);font-size:14px}
.link-muted{color:var(--muted);font-size:14px}
.link-muted:hover{color:var(--text)}

/* Filters */
.filters{
  background:var(--card2);
  border:1px solid var(--line);
  border-radius:var(--r);
  padding:14px;
  position:sticky;top:16px;height:fit-content;
}
.filters__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.filters__title{font-weight:700}
.filters__close{display:none}

@media (min-width: 981px){
  .filters__close{display:none!important}
}
.filters__block{margin:14px 0}
.filters__label{color:var(--muted);font-size:13px;margin-bottom:10px}
.toggle{display:flex;align-items:center;gap:10px;margin:10px 0;color:var(--text)}
.toggle input{transform:scale(1.1)}
.filters__footer{display:flex;gap:10px;margin-top:14px}

/* Chips */
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chip{
  background:rgba(17,24,39,.05);
  border:1px solid var(--line);
  color:var(--text);
  border-radius:999px;
  padding:8px 10px;
  cursor:pointer;
  font-size:13px;
}
.chip.is-active{background:#D61D2C;border-color:#D61D2C;color:#fff}

/* Grid cards */
.grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.card{
  display:flex;flex-direction:column;overflow:hidden;
  background:var(--card);
  border:1px solid var(--line);
  border-radius:var(--r);
  box-shadow:var(--shadow);
  position:relative;
}
.card__link{
  display:flex;
  flex-direction:column;
  flex:1;
  min-height:0;
  position:relative;
  z-index:1;
}
.card__link:focus-visible{
  outline:2px solid rgba(17,24,39,.35);
  outline-offset:2px;
  border-radius:var(--r);
}

.card__media{height:160px;background:var(--card2)}
.card__media img{width:100%;height:100%;object-fit:cover;display:block}
.card__body{padding:12px}
.card__title{font-weight:700;margin:0 0 6px;font-size:15px;line-height:1.25}
.card__addr{color:var(--muted);font-size:13px;margin:0 0 10px}
.price{display:flex;align-items:baseline;gap:8px;margin:0 0 10px}
.price__main{font-weight:800;font-size:18px}
.price__sub{color:var(--muted);font-size:12px;font-weight:400}
.amen{display:flex;flex-wrap:wrap;gap:8px}
.badge{
  font-size:12px;color:rgba(17,24,39,.88);
  background:rgba(17,24,39,.04);
  border:1px solid var(--line);
  border-radius:999px;
  padding:6px 8px;
}
.fav{
  position:absolute;top:10px;right:10px;
  width:40px;height:40px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(255,255,255,.78);
  border:1px solid rgba(17,24,39,.14);
  z-index:2;
  cursor:pointer;
}
.fav:hover{background:rgba(255,255,255,.92)}
.fav.is-on{background:rgba(255,255,255,.95)}

/* Apartment page */
.topbar{border-bottom:1px solid var(--line);background:rgba(255,255,255,.85);backdrop-filter: blur(10px);position:sticky;top:0}
.topbar__inner{display:flex;align-items:center;gap:12px;padding:10px 16px}
.apt{padding:18px 16px 40px}
.apt h1{margin:0 0 8px;font-size:24px;line-height:1.15}
.apt .addr{color:var(--muted);margin:0 0 18px}
.apt__grid{display:grid;grid-template-columns: 1.4fr .9fr;gap:16px}
.box{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:14px}
.gallery__main{width:100%;height:360px;background:var(--card2);border-radius:14px;overflow:hidden}
.gallery__main img{width:100%;height:100%;object-fit:contain;background:var(--card2);cursor:zoom-in}
.thumbs{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.thumb{width:92px;height:64px;border-radius:12px;overflow:hidden;border:1px solid var(--line);cursor:pointer;background:var(--card2)}
.thumb img{width:100%;height:100%;object-fit:cover}
.list{display:flex;flex-direction:column;gap:8px}
.row{display:flex;justify-content:space-between;gap:10px;color:var(--text)}
.row span{color:var(--muted)}
.kv{color:var(--muted);font-size:13px;display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
.kv > div{background:var(--card2);border:1px solid var(--line);border-radius:14px;padding:10px}
.skeleton{color:var(--muted);padding:18px;border:1px dashed var(--line);border-radius:var(--r)}

/* Lightbox */
.no-scroll{overflow:hidden}
.lightbox{
  position:fixed;inset:0;
  display:none;
  place-items:center;
  background:rgba(0,0,0,.82);
  z-index:1000;
  padding:18px;
}
.lightbox.is-open{display:grid}
.lightbox .frame{
  position:relative;
  z-index:1;
  width:min(1050px, 100%);
  border-radius:18px;
  overflow:hidden;
  background:#0b0f14;
  color:#fff;
  border:1px solid rgba(255,255,255,.12);
  box-shadow: 0 20px 60px rgba(0,0,0,.55);
}
.lightbox .backdrop{
  position:absolute;
  inset:0;
  background:transparent;
  z-index:0;
}

.lightbox .top{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:12px 14px;
  background:rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.12);
}
.lightbox .hint{color:rgba(255,255,255,.75);font-size:12px;margin-top:2px}
.lightbox .stage,
.lightbox .viewer{
  position:relative;
  height:min(75vh, 680px);
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.35);
}
.lightbox .photo,
.lightbox #lbImg{max-width:100%;max-height:100%;object-fit:contain}
.lightbox .nav-btn,
.lightbox .nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:999px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.35);
  color:#fff;
  cursor:pointer;
  font-size:28px;
  line-height:1;
}
.lightbox .nav-btn:hover,
.lightbox .nav:hover{background:rgba(0,0,0,.50)}
.lightbox .nav-btn.prev{left:10px}
.lightbox .nav-btn.next{right:10px}
/* Aliases for current lightbox HTML (viewer/nav/backdrop) */
.lightbox .viewer{ position:relative; }
.lightbox #lbImg{ display:block; }

.lightbox .nav--prev{ left:10px; }
.lightbox .nav--next{ right:10px; }

.lightbox .bottom{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:10px 14px;
  background:rgba(255,255,255,.04);
  border-top:1px solid rgba(255,255,255,.12);
}
.lightbox .counter{color:rgba(255,255,255,.76);font-size:13px}
.lightbox .download{color:#fff;font-size:13px;opacity:.86}
.lightbox .download:hover{opacity:1;text-decoration:underline}
.lightbox .icon-btn{border-color:rgba(255,255,255,.18);color:#fff}

/* Mobile */
@media (max-width: 980px){
  .layout{grid-template-columns:1fr}
  .filters{
    position:fixed;top:0;left:0;right:auto;bottom:0;
    width:min(360px,92vw);
    border-radius: 0 18px 18px 0;
    transform: translateX(-110%);
    transition: transform .2s ease;
    z-index:50;
    background:rgba(255,255,255,.96);
  }
  .filters.is-open{transform: translateX(0)}
  .filters__close{display:inline-flex}
  .grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hero, .hero__overlay, .hero__inner{min-height: 25vh}
  .hero h1{font-size:22px}
  .hero-controls{display:flex; justify-content:flex-start;}
}
@media (max-width: 520px){
  .grid{grid-template-columns:1fr}
  .card__media{height:190px}
  .apt__grid{grid-template-columns:1fr}
  .gallery__main{height:320px}
  .lightbox{padding:10px}
  .lightbox .nav-btn,
.lightbox .nav{width:40px;height:40px}
}


/* ===== Header (menu + logo + favourites) ===== */
:root{
  --header-h: 64px; /* mobile default */
}
@media (min-width: 900px){
  :root{ --header-h: 80px; }
}

.site-header{
  position: sticky;
  top: 0;
  z-index: 60;
  height: var(--header-h);
  /* Верхнее меню: чёрная подложка */
  background: rgba(0,0,0,.92);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.16);
  color: #ffffff;
}

.header-inner{
  max-width: 1100px;
  height: 100%;
  margin: 0 auto;
  padding: 0 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

/* Mobile header left padding fix */
@media (max-width: 899px){
  /* На мобиле визуально гамбургер из-за большой кнопки выглядит дальше от края. */
  /* Компенсируем: уменьшаем внутренний левый отступ и размер самой кнопки (иконка остаётся 36px). */
  .header-inner{ padding-left: 12px; padding-right: 16px; }
  .icon-btn--menu{ width: 44px; height: 44px; }
}

.header-left{
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
@media (min-width: 900px){
  .header-left{ gap: 20px; } /* logo further on desktop */
}

.icon-btn{
  width: 44px;
  height: 44px;
  display: grid;
  place-items: center;
  border: 0;
  border-radius: 12px;
  background: transparent;
  cursor: pointer;
}
.icon-btn:hover{ background: rgba(17,24,39,.06); }
.icon-btn:active{ transform: translateY(0.5px); }

/* bigger hamburger button */
.icon-btn--menu{
  width: 56px;
  height: 56px;
}

/* Header-specific button treatment (dark background) */
.site-header .icon-btn{ color: #ffffff; }
.site-header .icon-btn:hover{ background: rgba(255,255,255,.10); }

/* Hamburger icon: white bars + 50% bigger icon (24px -> 36px) */
.site-header #menuBtn img{
  width: 36px;
  height: 36px;
  filter: brightness(0) invert(1);
}

.logo-link{ display: inline-flex; align-items: center; min-width: 0; }
.logo-img{
  height: 36px; /* mobile (reduced ~30%) */
  width: auto;
  display: block;
  filter: drop-shadow(0 0 2px rgba(0,0,0,.35)); /* thin 2px shadow */
}
@media (min-width: 900px){
  .logo-img{ height: 46px; } /* PC (reduced ~30%) */
}

.fav-btn{
  height: 44px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
}
.fav-btn:hover{ opacity: .9; }
.fav-btn:active{ transform: translateY(0.5px); }

.fav-text{
  display: none;
  font-weight: 600;
  color: #b9b9b9; /* grey text on black */
}
@media (min-width: 900px){
  .fav-text{ display: inline; }
}

.fav-icon svg{
  width: 31px;   /* reduced 25% */
  height: 27px;  /* reduced 25% */
  display: block;
}

/* Favourite SVG colors (expects .heart-outline and .heart-fill in SVG) */
.fav-icon .heart-fill{ fill: #888888; }
.fav-icon .heart-outline{ stroke: #888888; fill: none; }
.fav-btn.has-favorites .fav-icon .heart-fill{ fill: #FFFFFF; }
.fav-btn.has-favorites .fav-icon .heart-outline{ stroke: #D61D2C; }

/* ===== Side menu drawer ===== */
.menu-overlay{
  position: fixed;
  inset: 0;
  z-index: 80;
  background: rgba(0,0,0,.70);
  opacity: 0;
  pointer-events: none;
  transition: opacity .18s ease;
}
.menu-overlay.is-open{
  opacity: 1;
  pointer-events: auto;
}

.menu-drawer{
  position: fixed;
  top: 0;
  left: 0;
  z-index: 90;
  width: min(320px, 86vw);
  height: 100vh;
  background: #000000; /* REQUIRED: black menu background */
  color: #FFFFFF;
  border-right: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 20px 60px rgba(17,24,39,.18);
  transform: translateX(-102%);
  transition: transform .18s ease;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.menu-drawer.is-open{ transform: translateX(0); }

.menu-drawer__top{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding-bottom: 8px;
  border-bottom: 0;
}
.menu-drawer__title{ font-weight: 700; color: #FFFFFF; font-size: 16px; }

/* Buttons inside dark menu */
.menu-drawer .icon-btn{ color:#FFFFFF; }
.menu-drawer .icon-btn:hover{ background: rgba(255,255,255,.10); }

#menuCloseBtn{ font-size: 24px; line-height: 1; font-weight: 700; }

.menu-link{
  display: block;
  padding: 12px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.18);
  background: transparent;
  color: #FFFFFF;
}
.menu-link:hover{ background: rgba(255,255,255,.08); }

body.k22-noscr{ overflow: hidden; }

/* ===== Small notice (used for empty favourites) ===== */
.k22-notice{
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  top: calc(var(--header-h) + 12px);
  z-index: 120;
  max-width: min(560px, calc(100vw - 32px));
  background: #fff;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  border-radius: 14px;
  padding: 12px 14px;
  display: none;
}
.k22-notice.is-show{ display: block; }
.k22-notice__text{ margin: 0; color: var(--text); font-size: 15px; line-height: 1.35; }


/* SVG icons: unified inline approach */
.k22-svg svg{ display:block; }

/* Hamburger icon color is controlled via CSS color */
.hamburger-icon{ color:#ffffff; }
.hamburger-icon svg{ width:48px; height:48px; }
.hamburger-icon svg *{
  stroke: currentColor !important;
  fill: currentColor !important;
}

/* Footer */
.site-footer{margin-top:24px}
.site-footer__top{background:#222222;color:#ffffff;padding:28px 0}
.site-footer__cols{display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:24px;align-items:start}
.site-footer__logo img{display:block;height:40px;width:auto}
.site-footer__note{margin:12px 0 0;color:rgba(255,255,255,.72);font-size:14px;line-height:1.5;max-width:42ch}
.site-footer__title{margin:0 0 10px;font-size:14px;font-weight:700;letter-spacing:.01em}
.site-footer__list{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.site-footer__link{color:rgba(255,255,255,.72);font-size:14px;text-decoration:none}
.site-footer__link:hover{color:#ffffff}
.site-footer__link:focus-visible{outline:2px solid rgba(255,255,255,.35);outline-offset:3px;border-radius:8px}

.site-footer__social{background:#222222;color:#ffffff;padding:0 0 24px}
.site-footer__social-buttons{display:flex;gap:10px}
.social-btn{width:40px;height:40px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:12px}
.social-btn__icon{width:20px;height:20px;display:block}
.social-btn:hover{background:rgba(255,255,255,.18)}
.social-btn:focus-visible{outline:2px solid rgba(255,255,255,.35);outline-offset:3px;border-radius:12px}

.site-footer__bottom{background:#000000;color:rgba(255,255,255,.72);padding:16px 0;font-size:13px}
.site-footer__legal div+div{margin-top:4px}

@media (max-width: 980px){
  .site-footer__cols{grid-template-columns:1fr}
  .site-footer__top{padding:24px 0}
}
