/* ------------------------------------------------- */
/*  Г А Л Е Р Е Я  –  общие стили                    */
/* ------------------------------------------------- */

/* ---------- базовые цвета и переменные ---------- */
:root{
  --bg-main:#141414;
  --bg-card:#1b1b1b;
  --txt-main:#fff;
  --txt-dim:#bbb;
  --accent:#ff333d;
  --radius:10px;
  --shadow:0 0 8px rgba(255,255,255,.08);
  font-family:'Montserrat',sans-serif;
}

body{
  background:var(--bg-main);
  color:var(--txt-main);
  margin:0;
  font-family:sans-serif;
  overflow-x:hidden;
}

/* ---------- шапка галереи ---------- */
.gallery-header{
  display:flex;
  align-items:center;
  gap:1rem;
  margin-bottom:1.5rem;
  position:relative;
  height: 50px;
}

.gallery-header .back-button{
  position:absolute;
  left:0;
  top:50%;
  transform:translateY(-50%);
  color:var(--txt-dim);
  text-decoration:none;
  font-size:16px;
  font-weight:600;
  transition:color .2s;
}
.gallery-header .back-button:hover{color:var(--accent)}

.gallery-header .gallery-logo{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:150px;
  height: 60px;
  opacity:.8;
}

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

.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 ---------- */
.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;
}

/* ---------- кнопки ---------- */
.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}
}
