﻿:root{
  --bg:#020202;
  --fg:#f5f5f5;
  --muted:#a0a0a0;
  --border:rgba(255,255,255,.18);
}

/* Сброс */
*{ box-sizing:border-box; margin:0; padding:0; }
html,body{ height:100%; }

body{
  background:#000;
  color:var(--fg);
  font:16px/1.55 ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
}

/* Верхняя панель */
.topbar{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:30;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 16px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:rgba(0,0,0,.88);
  backdrop-filter:blur(4px);
}

.nav{
  display:flex;
  align-items:center;
  gap:14px;
}

.nav a{
  color:var(--muted);
  text-decoration:none;
  font-size:.8rem;
}
.nav a:hover{ color:var(--fg); }

.brand{
  color:var(--fg);
  text-decoration:none;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:700;
}

/* чтобы не становилась фиолетовой / синей при visited/hover */
.brand:link,
.brand:visited{
  color:var(--fg);
}
.brand:hover{
  color:var(--fg);
}

/* кнопка-бургер */
.nav-toggle{
  display:none; /* на десктопе скрыта */
  position:relative;
  width:26px;
  height:20px;
  border:none;
  padding:0;
  margin-left:auto;
  background:transparent;
  cursor:pointer;
}
.nav-toggle span{
  position:absolute;
  left:0;
  right:0;
  height:2px;
  background:var(--fg);
  border-radius:999px;
  transition:transform .2s ease, opacity .2s ease;
}
.nav-toggle span:first-child{ top:4px; }
.nav-toggle span:last-child{ bottom:4px; }

/* Центрирование блока */
.shell{
  min-height:100%;
  display:grid;
  place-items:center;
  padding:80px 16px 28px;   /* отступ сверху под фиксированную шапку */
}


/* Карточка */
.panel{
  width:min(820px,100%);
  background:rgba(0,0,0,.92);
  border-radius:20px;
  border:1px solid var(--border);
  padding:24px 22px;
  position:relative;
  overflow:hidden;
  box-shadow:
    0 0 0 1px rgba(255,255,255,.03),
    0 26px 70px rgba(0,0,0,.9);
}

/* Лёгкий шум / виньетка */
.panel::before,
.panel::after{
  content:"";
  position:absolute;
  pointer-events:none;
}

/* шум пусть остаётся поверх всей панели */
.panel::before{
  inset:-40px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='3' stitchTiles='noStitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.25'/%3E%3C/svg%3E");
  mix-blend-mode:soft-light;
}

/* виньетка только сверху, фиксированной высоты */
/* виньетка на всю панель */
.panel::after{
  left:-40px;
  right:-40px;
  top:-40px;
  bottom:-40px;     /* ключевое: вместо height */
  background:radial-gradient(circle at 50% 0,
    transparent 0,
    transparent 45%,
    rgba(0,0,0,.9) 100%);
}



/* Текст */
.tag{
  color:var(--muted);
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:.72rem;
  margin-bottom:8px;
}
.lead{
  margin-top:10px;
  font-size:1.02rem;
}
.hint{
  margin-top:14px;
  font-size:.9rem;
  color:var(--muted);
}


/* Глитч заголовка в Ч/Б */
.glitch{
  position:relative;
  font-size:clamp(80px, 15vw, 150px);
  letter-spacing:.12em;
  text-transform:uppercase;
}
.glitch::before,
.glitch::after{
  content:attr(data-text);
  position:absolute;
  inset:0;
  color:var(--fg);
  mix-blend-mode:screen;
}
.glitch::before{
  transform:translate(-2px,0);
  clip-path:inset(0 0 55% 0);
  opacity:.7;
  animation:glitch-top 2.6s infinite linear;
}
.glitch::after{
  transform:translate(2px,0);
  clip-path:inset(45% 0 0 0);
  opacity:.7;
  animation:glitch-bottom 3.1s infinite linear reverse;
}

@keyframes glitch-top{
  0%{ transform:translate(-2px,0); }
  25%{ transform:translate(-4px,-1px); }
  50%{ transform:translate(0,0); }
  75%{ transform:translate(-3px,1px); }
  100%{ transform:translate(-2px,0); }
}
@keyframes glitch-bottom{
  0%{ transform:translate(2px,0); }
  20%{ transform:translate(3px,1px); }
  55%{ transform:translate(0,0); }
  80%{ transform:translate(4px,-1px); }
  100%{ transform:translate(2px,0); }
}

/* Уважение к prefers-reduced-motion */
@media (prefers-reduced-motion: reduce){
  .glitch::before,
  .glitch::after{
    animation:none;
    clip-path:none;
    transform:none;
  }
}

/* Адаптив */
@media (max-width:600px){
  .panel{ padding:20px 16px; border-radius:14px; }
  .topbar{ padding:10px 12px; }
  .nav{ display:none; }
}
.secret-dot{
  position:fixed;
  right:14px;
  bottom:14px;
  width:14px;
  height:14px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.04);
  padding:0;
  margin:0;
  cursor:pointer;
  outline:none;
  /* делаем её чуть “потерянной” */
  opacity:.35;
  transition:opacity .2s ease, transform .2s ease;
}
.secret-dot:hover{
  opacity:.8;
  transform:scale(1.1);
}
.secret-dot:focus-visible{
  outline:1px dashed rgba(255,255,255,.5);
}

.gallery{
  margin-top:22px;
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:12px;
}
.frame{
  position:relative;
  overflow:hidden;
  border-radius:10px;
  border:1px solid var(--border);
  background:#000;
}
.frame img{
  width:100%;
  height:100%;
  display:block;
  object-fit:cover;
  filter:grayscale(100%) contrast(1.05);
  transition:transform .35s ease, filter .35s ease, opacity .35s ease;
}
.frame:hover img{
  transform:scale(1.03);
  opacity:.95;
}
.thumb{
  border:none;
  padding:0;
  margin:0;
  width:100%;
  height:100%;
  background:transparent;
  cursor:pointer;
}
.thumb img{
  width:100%;
  height:100%;
  display:block;
}

/* лайтбокс */
.lightbox{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(0,0,0,.85);
  opacity:0;
  pointer-events:none;
  transition:opacity .25s ease;
  z-index:40;
}
.lightbox.is-open{
  opacity:1;
  pointer-events:auto;
}
.lightbox-backdrop{
  position:absolute;
  inset:0;
}

/* контейнер без жёсткой высоты */
.lightbox-inner{
  position:relative;
  max-width:90vw;
  max-height:90vh;
  border-radius:12px;
  overflow:hidden;           /* вернули, но теперь размер задаёт сама картинка */
  border:1px solid var(--border);
  box-shadow:0 20px 80px rgba(0,0,0,.9);
  background:#000;
}

.lightbox-inner img{
  display:block;
  width:auto;
  height:auto;
  max-width:90vw;
  max-height:90vh;
  object-fit:contain;
  background:#000;
}


/* секретная точка */
.secret-dot{
  position:fixed;
  right:14px;
  bottom:14px;
  width:14px;
  height:14px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.04);
  padding:0;
  margin:0;
  cursor:pointer;
  outline:none;
  opacity:.35;
  transition:opacity .2s ease, transform .2s ease;
}
.secret-dot:hover{
  opacity:.8;
  transform:scale(1.1);
}
@media (max-width: 600px){

  body{
    font-size:14px;
  }

  .topbar{
    padding:10px 12px;
    font-size:.75rem;
  }

  .brand{
    font-size:.8rem;
    letter-spacing:.06em;
  }

  /* прячем пункты меню, оставляем только бренд */
  .nav{
    display:none;
  }

  .shell{
    padding:72px 10px 20px;   /* меньше отступы вокруг панели */
  }

  .panel{
    width:100%;
    padding:18px 14px;
    border-radius:12px;
  }

  .tag{
    font-size:.7rem;
    letter-spacing:.14em;
  }

  .glitch{
    font-size: clamp(40px, 14vw, 68px);  /* меньше заголовок на главной */
  }

  .lead{
    font-size:.95rem;
  }

  .hint{
    font-size:.8rem;
  }

  /* галерея: крупнее карточки по одной/две в ряд */
  .gallery{
    grid-template-columns:repeat(auto-fit, minmax(140px, 1fr));
    gap:10px;
  }

  .frame{
    border-radius:8px;
  }

  .secret-dot{
    right:10px;
    bottom:10px;
    width:12px;
    height:12px;
  }
}
@media (max-width: 600px){

  .topbar{
    padding:10px 12px;
  }

  .brand{
    font-size:.8rem;
  }

  .nav-toggle{
    display:block;      /* показываем бургер */
  }

  .nav{
    position:absolute;
    top:100%;
    right:10px;
    margin-top:6px;
    padding:8px 10px;
    border-radius:10px;
    background:rgba(0,0,0,.96);
    border:1px solid rgba(255,255,255,.12);
    box-shadow:0 12px 40px rgba(0,0,0,.8);
    display:none;       /* по умолчанию скрыто */
    flex-direction:column;
    align-items:flex-start;
    gap:6px;
    min-width:130px;
  }

  .nav a{
    font-size:.8rem;
    color:var(--fg);
  }

  .nav.nav-open{
    display:flex;       /* показываем при клике */
  }

  .shell{
    padding:72px 10px 20px;
  }

  .panel::after{
    left:-20px;
    right:-20px;
    top:-20px;
    bottom:-20px;   /* ключевое */
    height:auto;    /* на всякий случай */
    background:radial-gradient(circle at 50% 0,
      transparent 0,
      transparent 60%,
      rgba(0,0,0,.85) 100%);
  }

}
