/* ------------------------------------------------- */
/*  Г А Л Е Р Е Я  –  общие стили                    */
/* ------------------------------------------------- */
body{
  background:#141414;
  color:#fff;
  margin:0;
  font-family:sans-serif;
  overflow-x: hidden; 
}

.logo{display:flex;justify-content:center;margin:0 0 20px;}
.logo img{width:150px;height:60px;object-fit:contain}

/* контейнер */
.gallery-container{
  position:relative;
  max-width:900px;
  margin:200px auto;
  padding:20px;
  border-radius:15px;
  background:rgba(255,255,255,.1);
  z-index:1;
}

/* заголовок */
.gallery-container h1{
  margin:0 0 20px;
  font-size:28px;
  font-weight:600;
  text-align:center;
}

/* ------------------------------------------------- */
/*  С Е Т К А                                         */
/* ------------------------------------------------- */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:16px;
}

.gallery-item{
  background:#000;
  border-radius:8px;
  overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,.3);
  transition:transform .2s ease,box-shadow .2s ease;
}
.gallery-item img{width:100%;display:block}

.gallery-item:hover{
  transform:scale(1.02);
  box-shadow:0 4px 12px rgba(0,0,0,.5);
}

/* ------------------------------------------------- */
/*  Ф У Т Е Р                                         */
/* ------------------------------------------------- */
.gallery-footer{margin:2rem 0;text-align:center}
.gallery-footer a{
  color:#fff;font-size:16px;text-decoration:none;
  transition:color .2s,text-decoration .2s;
}
.gallery-footer a:hover{color:#66afe9;text-decoration:underline}

/* ------------------------------------------------- */
/*  О В Е Р Л Е Й  (крупное изображение)             */
/* ------------------------------------------------- */
.overlay{
  position:fixed;inset:0;
  background:rgba(0,0,0,.8);
  display:flex;align-items:center;justify-content:center;
  z-index:999; /* поверх всего */
}
.overlay.hidden{display:none}

/* само изображение */
#overlay-img{
  max-width:70vw;max-height:70vh;
  border-radius:8px;
  box-shadow:0 4px 20px rgba(0,0,0,.7);
  cursor:grab;
  transition:transform .25s ease;
  user-select:none;
}

/* ------------------------------------------------- */
/*  К Н О П К И  (prev / next / close / zoom)        */
/* ------------------------------------------------- */
.nav-btn,
.close-btn,
.zoom-box button{
  position:absolute;
  background:none;
  border:0;
  font-size:2.6rem;
  line-height:1;
  color:#fff;
  cursor:pointer;
  user-select:none;
  padding:.25rem .6rem;
}

/* стрелки */
#prev{left:1rem;top:50%;transform:translateY(-50%)}
#next{right:1rem;top:50%;transform:translateY(-50%)}

/* крестик закрытия */
.close-btn{top:6.6rem;right:.8rem;font-size:3rem}

/* блок зума */
.zoom-box{
  position:absolute;
  right:4rem;
  bottom:1rem;
  display:flex;
  gap:.6rem;
}
.zoom-box button{
  font-size:2.2rem;
  background:#222;
  border-radius:.25rem;
  padding:.15rem .55rem;
}

/* ------------------------------------------------- */
/*  А Д А П Т И В                                    */
/* ------------------------------------------------- */
@media (max-width:600px){
  .gallery-container{margin:100px 10px;padding:15px}
  .gallery-container h1{font-size:24px}
  .gallery-grid{gap:12px}
  #prev,#next{font-size:2.2rem}
  .zoom-box{right:3rem;bottom:.8rem}
}
