/* ============ amid gallery — minimalist, mobile-first ============ */
:root{
  --red:#e62b1e;
  --red-dark:#c21f14;
  --ink:#16181d;
  --muted:#6b7280;
  --line:#ececec;
  --bg:#ffffff;
  --surface:#f6f6f7;
  --radius:16px;
  --shadow:0 1px 2px rgba(16,18,29,.04), 0 8px 24px rgba(16,18,29,.06);
  --shadow-hover:0 6px 18px rgba(16,18,29,.10), 0 18px 40px rgba(16,18,29,.12);
  --maxw:1200px;
  --pad:clamp(16px, 4vw, 40px);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

.container{
  width:100%;
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:var(--pad);
}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:30;
  background:rgba(255,255,255,.85);
  backdrop-filter:saturate(180%) blur(12px);
  -webkit-backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--line);
  padding-top:env(safe-area-inset-top);
}
.header-inner{
  display:flex;align-items:center;gap:14px;
  min-height:78px;
}
.brand-logo{height:52px;width:auto;display:block}
.brand-tag{
  font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--muted);font-weight:600;
  padding:4px 10px;border:1px solid var(--line);border-radius:999px;
}
@media(max-width:560px){
  .header-inner{min-height:66px;gap:10px}
  .brand-logo{height:46px}
  .brand-tag{font-size:.6rem;padding:3px 8px;letter-spacing:.1em}
}

/* ---------- Hero ---------- */
.hero{padding:clamp(28px,7vw,64px) 0 clamp(18px,4vw,32px)}
.hero-title{
  margin:0;
  font-size:clamp(1.7rem,6vw,3rem);
  font-weight:800;letter-spacing:-.02em;line-height:1.05;
}
.hero-sub{
  margin:.6em 0 0;
  max-width:46ch;
  color:var(--muted);
  font-size:clamp(.95rem,2.5vw,1.075rem);
}

/* ---------- Gallery grid ---------- */
.gallery-section{padding-bottom:clamp(40px,8vw,80px)}
.grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:clamp(10px,2.5vw,22px);
}
@media(min-width:640px){.grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:980px){.grid{grid-template-columns:repeat(4,1fr)}}

.card{
  position:relative;
  border:none;
  padding:0;
  background:var(--surface);
  border-radius:var(--radius);
  overflow:hidden;
  cursor:pointer;
  box-shadow:var(--shadow);
  text-align:left;
  transition:transform .25s ease, box-shadow .25s ease;
  -webkit-tap-highlight-color:transparent;
}
.card:active{transform:scale(.985)}
@media(hover:hover){
  .card:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
  .card:hover .card-img{transform:scale(1.04)}
}
.card-media{
  position:relative;
  aspect-ratio:1/1;
  overflow:hidden;
  background:var(--surface);
}
.card-img{
  width:100%;height:100%;
  object-fit:cover;
  transition:transform .45s ease;
}
.card-count{
  position:absolute;top:10px;right:10px;
  background:rgba(22,24,29,.72);
  color:#fff;font-size:.72rem;font-weight:600;
  padding:3px 9px;border-radius:999px;
  backdrop-filter:blur(4px);
  display:flex;align-items:center;gap:5px;
}
.card-body{
  padding:11px 13px 13px;
  display:flex;align-items:center;justify-content:space-between;gap:8px;
}
.card-title{font-size:.95rem;font-weight:600;letter-spacing:-.01em}
.card-arrow{color:var(--red);font-size:1.05rem;flex:none}

/* ---------- Footer ---------- */
.site-footer{
  border-top:1px solid var(--line);
  padding:28px 0 calc(28px + env(safe-area-inset-bottom));
  margin-top:auto;
}
.footer-inner{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.footer-logo{height:36px;opacity:.9}
.footer-copy{color:var(--muted);font-size:.85rem}

/* ---------- Lightbox ---------- */
.lightbox{
  position:fixed;inset:0;z-index:100;
  display:none;
  flex-direction:column;
  background:rgba(12,13,16,.97);
  padding-top:env(safe-area-inset-top);
  padding-bottom:env(safe-area-inset-bottom);
  touch-action:none;
}
.lightbox.open{display:flex}
.lb-topbar{
  display:flex;align-items:center;gap:12px;
  padding:14px var(--pad);
  color:#fff;
}
.lb-title{font-weight:600;font-size:1rem}
.lb-counter{color:rgba(255,255,255,.6);font-size:.85rem;font-variant-numeric:tabular-nums}
.lb-close{margin-left:auto}
.lb-btn{
  background:rgba(255,255,255,.1);
  color:#fff;border:none;cursor:pointer;
  width:44px;height:44px;border-radius:50%;
  font-size:1.6rem;line-height:1;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s ease, transform .15s ease;
  -webkit-tap-highlight-color:transparent;
}
.lb-btn:active{transform:scale(.92)}
@media(hover:hover){.lb-btn:hover{background:rgba(255,255,255,.22)}}
.lb-close{font-size:1.9rem}
.lb-stage{
  flex:1;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  padding:4px var(--pad);
  min-height:0;
}
.lb-image{
  max-width:100%;max-height:100%;
  width:auto;height:auto;
  object-fit:contain;
  border-radius:8px;
  user-select:none;-webkit-user-drag:none;
  animation:lbFade .25s ease;
}
@keyframes lbFade{from{opacity:0}to{opacity:1}}
.lb-nav{
  position:absolute;top:50%;transform:translateY(-50%);
  width:52px;height:52px;font-size:2rem;z-index:2;
}
.lb-prev{left:max(10px,env(safe-area-inset-left))}
.lb-next{right:max(10px,env(safe-area-inset-right))}
.lb-thumbs{
  display:flex;gap:8px;
  overflow-x:auto;
  padding:12px var(--pad) 16px;
  scrollbar-width:thin;
  -webkit-overflow-scrolling:touch;
}
.lb-thumbs::-webkit-scrollbar{height:5px}
.lb-thumbs::-webkit-scrollbar-thumb{background:rgba(255,255,255,.25);border-radius:99px}
.lb-thumb{
  flex:none;
  width:58px;height:58px;
  border-radius:9px;overflow:hidden;
  cursor:pointer;
  opacity:.5;
  border:2px solid transparent;
  transition:opacity .2s ease, border-color .2s ease;
  background:#222;
}
.lb-thumb img{width:100%;height:100%;object-fit:cover}
.lb-thumb.active{opacity:1;border-color:var(--red)}

/* Hide side nav arrows on small touch screens — swipe instead */
@media(max-width:680px){
  .lb-nav{display:none}
}

/* ---------- Phone refinements ---------- */
@media(max-width:560px){
  .hero{padding:22px 0 14px}
  .hero-sub{max-width:38ch}
  .grid{gap:12px}
  .card-body{padding:10px 12px 12px}
  .card-title{font-size:.9rem}
  .card-count{top:8px;right:8px;font-size:.74rem;padding:3px 8px}
  /* bigger, easier-to-tap thumbnails in the viewer */
  .lb-thumb{width:64px;height:64px}
  .lb-topbar{padding:12px 16px}
  .lb-title{font-size:.95rem}
  .lb-stage{padding:4px 10px}
  /* hint that you can swipe between photos */
  .lb-counter::after{content:" · смахните";color:rgba(255,255,255,.4)}
}

body.no-scroll{overflow:hidden}

@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;transition-duration:.01ms!important}
}
