/* gallery.html specific */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
  html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
  body{font-family:'Inter',sans-serif;font-weight:400;font-size:15px;line-height:1.6;color:#0A0A0A;background:#FFFFFF}
  img{max-width:100%;display:block}
  a{color:inherit;text-decoration:none}
  button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}

  .header{position:sticky;top:0;background:rgba(255,255,255,0.96);backdrop-filter:blur(8px);border-bottom:0.5px solid #E5E5E5;z-index:100}
  .header-inner{max-width:1280px;margin:0 auto;padding:18px 32px;display:flex;align-items:center;justify-content:space-between;gap:32px}
  .logo{display:inline-block;line-height:0}.logo img{height:48px;width:auto;display:block}
  .nav{display:flex;gap:28px;font-size:11px;letter-spacing:1.5px;color:#0A0A0A}
  .nav a{transition:opacity .2s}
  .nav a:hover{opacity:0.5}
  .nav a.active{font-weight:500}
  .header-right{display:flex;align-items:center;gap:18px;font-size:11px;letter-spacing:1px}
  .lang{color:#888}
  .btn-book{background:#0A0A0A;color:#FFF;padding:11px 20px;font-size:11px;letter-spacing:1.5px;font-weight:500;transition:background .2s}
  .btn-book:hover{background:#333}

  .breadcrumb{max-width:1280px;margin:0 auto;padding:16px 32px;font-size:11px;letter-spacing:1.5px;color:#888}
  .breadcrumb a{color:#888;transition:color .2s}
  .breadcrumb a:hover{color:#0A0A0A}

  .pre-label{font-size:10px;letter-spacing:4px;color:#888;text-transform:uppercase}

  .page-head{max-width:1280px;margin:0 auto;padding:32px 32px 48px}
  .page-head-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:end}
  .page-head-text h1{font-family:'Fraunces',serif;font-size:88px;font-weight:400;line-height:0.94;letter-spacing:-3px;margin-top:14px}
  .page-head-text h1 em{font-style:italic;color:#888;font-weight:300}
  .page-head-text p{font-size:15px;color:#555;margin-top:24px;max-width:520px;line-height:1.7}
  .page-head-visual{aspect-ratio:4/3;overflow:hidden;background:#1a1a1a;position:relative}
  .page-head-visual img{width:100%;height:100%;object-fit:cover}
  .page-head-visual-label{position:absolute;bottom:16px;left:16px;background:rgba(255,255,255,0.95);padding:7px 12px;font-size:10px;letter-spacing:2px;font-weight:500;color:#0A0A0A}

  /* ФИЛЬТРЫ */
  .filters{max-width:1280px;margin:0 auto;padding:0 32px 32px;display:flex;gap:24px;flex-wrap:wrap;border-bottom:0.5px solid #E5E5E5;padding-bottom:24px}
  .filter-btn{font-size:11px;letter-spacing:2px;color:#888;cursor:pointer;padding:6px 0;border-bottom:0.5px solid transparent;transition:all .2s;background:transparent;border-top:none;border-left:none;border-right:none}
  .filter-btn:hover{color:#0A0A0A}
  .filter-btn.active{color:#0A0A0A;border-bottom-color:#0A0A0A}

  /* MASONRY */
  .gallery-masonry{max-width:1280px;margin:0 auto;padding:48px 32px 96px;column-count:3;column-gap:12px}
  .gallery-tile{break-inside:avoid;margin-bottom:12px;overflow:hidden;background:#1a1a1a;cursor:pointer;position:relative}
  .gallery-tile img{width:100%;display:block;transition:transform .6s ease,opacity .3s}
  .gallery-tile:hover img{transform:scale(1.04)}
  .gallery-tile.hidden{display:none}

  /* LIGHTBOX */
  .lightbox{position:fixed;inset:0;background:rgba(10,10,10,0.95);z-index:1000;display:none;align-items:center;justify-content:center;padding:40px;cursor:pointer}
  .lightbox.open{display:flex}
  .lightbox img{max-width:90vw;max-height:90vh;object-fit:contain}
  .lightbox-close{position:absolute;top:24px;right:24px;color:#FFF;font-size:32px;background:none;border:none;cursor:pointer;line-height:1}

  /* INLINE CALLBACK */
  .inline-callback{background:#0A0A0A;color:#FFF;padding:64px 0}
  .inline-callback-wrap{max-width:1280px;margin:0 auto;padding:0 32px;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
  .inline-callback h3{font-family:'Fraunces',serif;font-size:38px;font-weight:400;line-height:1.05;letter-spacing:-1.5px;color:#FFF}
  .inline-callback h3 em{font-style:italic;color:#888;font-weight:300}
  .inline-callback .inline-intro{font-size:13px;color:#999;margin-top:12px;line-height:1.6;max-width:360px}
  .inline-form{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .inline-form input{grid-column:span 2;padding:14px 16px;border:0.5px solid rgba(255,255,255,0.25);background:transparent;color:#FFF;font-family:inherit;font-size:14px;outline:none;transition:border-color .2s}
  .inline-form input::placeholder{color:#888}
  .inline-form input:focus{border-color:#FFF}
  .inline-form input[name="name"],.inline-form input[name="phone"]{grid-column:span 1}
  .inline-form button{grid-column:span 2;background:#FFF;color:#0A0A0A;padding:14px;border:none;font-size:11px;letter-spacing:2.5px;font-weight:500;cursor:pointer;font-family:inherit;transition:background .2s}
  .inline-form button:hover{background:#E5E5E5}

  .footer{background:#FFF;border-top:0.5px solid #E5E5E5}
  .footer-inner{max-width:1280px;margin:0 auto;padding:60px 32px 30px;display:grid;grid-template-columns:repeat(4,1fr);gap:40px}
  .footer-col h4{font-size:11px;letter-spacing:2.5px;font-weight:500;color:#0A0A0A;margin-bottom:18px}
  .footer-col p,.footer-col a{font-size:12px;color:#666;line-height:1.9;display:block}
  .footer-col a:hover{color:#0A0A0A}
  .footer-bottom{max-width:1280px;margin:0 auto;padding:20px 32px;border-top:0.5px solid #E5E5E5;display:flex;justify-content:space-between;font-size:10px;letter-spacing:1px;color:#999}
  .footer-bottom a{margin-left:24px;color:#999}

  @media (max-width:1024px){
    .nav{display:none}
    .page-head-grid{grid-template-columns:1fr;gap:32px}
    .page-head-text h1{font-size:64px}
    .gallery-masonry{column-count:2}
    .footer-inner{grid-template-columns:repeat(2,1fr)}
    .inline-callback-wrap{grid-template-columns:1fr;gap:32px;padding:0 20px}
  }
  @media (max-width:640px){
    .header-inner{padding:14px 20px}
    .breadcrumb,.page-head,.filters,.gallery-masonry{padding-left:20px;padding-right:20px}
    .page-head-text h1{font-size:48px;letter-spacing:-2px}
    .gallery-masonry{column-count:1}
    .filters{gap:16px}
    .footer-inner{grid-template-columns:1fr;padding:48px 20px 24px}
  }

  @media (prefers-reduced-motion:no-preference){
    .fade-in{opacity:0;transform:translateY(20px);animation:fadeUp .8s ease forwards}
    @keyframes fadeUp{to{opacity:1;transform:translateY(0)}}
  }