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

  /* HERO заголовок */
  .room-hero{max-width:1280px;margin:0 auto;padding:32px 32px}
  .room-hero-grid{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap}
  .room-hero-text{max-width:760px}
  .room-hero h1{font-family:'Fraunces',serif;font-size:88px;font-weight:400;line-height:0.94;letter-spacing:-3px;margin-top:14px}
  .room-hero h1 em{font-style:italic;color:#888;font-weight:300}
  .btn-secondary{border:0.5px solid #0A0A0A;color:#0A0A0A;padding:12px 22px;font-size:11px;letter-spacing:2px;font-weight:500;transition:all .2s;display:inline-block;background:#FFF}
  .btn-secondary:hover{background:#0A0A0A;color:#FFF}

  /* ГАЛЕРЕЯ — большая на всю ширину */
  .gallery{max-width:1280px;margin:0 auto;padding:0 32px 64px}
  .gallery-main{aspect-ratio:16/9;overflow:hidden;background:#1a1a1a;position:relative;cursor:pointer}
  .gallery-main img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
  .gallery-main:hover img{transform:scale(1.02)}
  .gallery-main-counter{position:absolute;bottom:16px;right:16px;background:rgba(10,10,10,0.7);color:#FFF;padding:7px 14px;font-size:10px;letter-spacing:2px}
  .gallery-thumbs{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-top:8px}
  .gallery-thumb{aspect-ratio:4/3;overflow:hidden;background:#1a1a1a;cursor:pointer;position:relative;transition:opacity .2s}
  .gallery-thumb img{width:100%;height:100%;object-fit:cover}
  .gallery-thumb:hover{opacity:0.85}
  .gallery-thumb-more{position:absolute;inset:0;background:rgba(10,10,10,0.7);color:#FFF;display:flex;align-items:center;justify-content:center;font-size:13px;letter-spacing:1.5px;font-weight:500}

  /* ХАРАКТЕРИСТИКИ + KEY CTA */
  .room-key{max-width:1280px;margin:0 auto;padding:0 32px 64px}
  .room-meta-row{display:grid;grid-template-columns:repeat(5,1fr) auto;gap:0;border-top:0.5px solid #0A0A0A;border-bottom:0.5px solid #E5E5E5;align-items:center}
  .room-meta-item{padding:24px 28px;border-right:0.5px solid #E5E5E5;text-align:center}
  .room-meta-item:first-child{padding-left:0}
  .room-meta-label{color:#888;letter-spacing:1.5px;font-size:10px;font-weight:500}
  .room-meta-value{font-weight:500;color:#0A0A0A;margin-top:6px;font-size:18px;white-space:nowrap}
  .room-meta-cta{padding-left:32px}
  .btn-primary-big{background:#0A0A0A;color:#FFF;padding:18px 28px;font-size:12px;letter-spacing:2px;font-weight:500;transition:background .2s;display:inline-flex;align-items:center;gap:8px;white-space:nowrap}
  .btn-primary-big:hover{background:#333}
  .btn-primary-big .ext-icon{font-size:14px;opacity:0.7}

  /* ОПИСАНИЕ */
  .room-content{max-width:880px;margin:0 auto;padding:0 32px 64px}
  .room-content h2{font-family:'Fraunces',serif;font-size:40px;font-weight:400;line-height:1.05;letter-spacing:-1.2px;margin-bottom:24px}
  .room-content h2 em{font-style:italic;color:#888;font-weight:300}
  .room-content p{font-size:16px;color:#333;line-height:1.85;margin-bottom:18px}
  .room-content p:last-child{margin-bottom:0}

  /* Тонкая справка о цене внизу описания */
  .price-hint{max-width:880px;margin:0 auto 80px;padding:0 32px}
  .price-hint-inner{padding:18px 22px;background:#FAFAFA;border-left:1.5px solid #DDD;font-size:13px;color:#888;line-height:1.6}
  .price-hint-inner strong{color:#555;font-weight:500}

  /* УДОБСТВА */
  .amenities{background:#FAFAFA;padding:0}
  .amenities-inner{max-width:1280px;margin:0 auto;padding:80px 32px}
  .amenities-head{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:48px}
  .amenities-head h2{font-family:'Fraunces',serif;font-size:48px;font-weight:400;line-height:1;letter-spacing:-1.5px;margin-top:14px}
  .amenities-head h2 em{font-style:italic;color:#888;font-weight:300}
  .amenities-head-right{font-size:13px;color:#555;line-height:1.7;padding-bottom:6px;max-width:380px}
  .amenities-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0 40px;border-top:0.5px solid #0A0A0A}
  .amenity-item{padding:14px 0;border-bottom:0.5px solid #DDD;font-size:14px;display:flex;align-items:center;gap:12px}

  /* FAQ */
  .room-faq{max-width:1280px;margin:0 auto;padding:80px 32px}
  .room-faq-grid{display:grid;grid-template-columns:1fr 1.6fr;gap:60px}
  .room-faq h2{font-family:'Fraunces',serif;font-size:48px;font-weight:400;line-height:1;letter-spacing:-1.5px;margin-top:14px}
  .room-faq h2 em{font-style:italic;color:#888;font-weight:300}
  .room-faq-sub{font-size:13px;color:#555;margin-top:18px;line-height:1.7;max-width:280px}
  .faq-item{display:block;border-top:0.5px solid #DDD;padding:18px 0;cursor:pointer;transition:color .2s}
  .faq-item:first-child{border-top:0.5px solid #0A0A0A}
  .faq-item:last-child{border-bottom:0.5px solid #DDD}
  .faq-item-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;font-size:15px}
  .faq-item-head .faq-q{flex:1;min-width:0;font-weight:500}
  .faq-item-head .faq-plus{flex-shrink:0;font-size:18px;font-weight:300;color:#888;transition:transform .3s;margin-top:2px}
  .faq-item.open .faq-plus{transform:rotate(45deg)}
  .faq-answer{font-size:13px;color:#555;line-height:1.7;margin-top:0;max-height:0;overflow:hidden;transition:max-height .3s ease,margin-top .3s ease}
  .faq-item.open .faq-answer{max-height:300px;margin-top:14px}

  /* CROSS-SELL */
  .cross-sell{background:#FAFAFA;padding:80px 0}
  .cross-sell-inner{max-width:1280px;margin:0 auto;padding:0 32px}
  .cross-sell-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:40px;gap:40px;flex-wrap:wrap}
  .cross-sell-head h2{font-family:'Fraunces',serif;font-size:42px;font-weight:400;line-height:1;letter-spacing:-1.5px;margin-top:14px}
  .cross-card{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:center;padding:32px;background:#FFF;border:0.5px solid #E5E5E5;transition:border-color .2s}
  .cross-card:hover{border-color:#0A0A0A}
  .cross-image{aspect-ratio:4/3;overflow:hidden;background:#1a1a1a}
  .cross-image img{width:100%;height:100%;object-fit:cover}
  .cross-info-tag{font-size:11px;letter-spacing:2.5px;color:#888;font-weight:500}
  .cross-info-title{font-family:'Fraunces',serif;font-size:36px;font-weight:400;line-height:1;letter-spacing:-1px;margin-top:12px}
  .cross-info-title em{font-style:italic;color:#888;font-weight:300}
  .cross-info-meta{font-size:12px;color:#555;margin-top:14px;line-height:1.6}
  .cross-cta{margin-top:20px;font-size:11px;letter-spacing:1.5px;color:#0A0A0A;border-bottom:0.5px solid #0A0A0A;padding-bottom:3px;display:inline-block;transition:opacity .2s}
  .cross-card:hover .cross-cta{opacity:0.6}

  /* 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}
    .room-hero h1{font-size:56px}
    .gallery-thumbs{grid-template-columns:repeat(4,1fr)}
    .gallery-thumb:nth-child(5),.gallery-thumb:nth-child(6){display:none}
    .gallery-thumb:nth-child(4) .gallery-thumb-more{display:flex}
    .room-meta-row{grid-template-columns:repeat(2,1fr);border-bottom:0.5px solid #E5E5E5}
    .room-meta-item{border-right:0.5px solid #E5E5E5;border-bottom:0.5px solid #E5E5E5;padding:20px 24px}
    .room-meta-item:nth-child(2n){border-right:none}
    .room-meta-cta{grid-column:span 2;padding:24px;border-top:0.5px solid #E5E5E5}
    .btn-primary-big{width:100%;justify-content:center}
    .amenities-head{grid-template-columns:1fr;gap:20px}
    .amenities-grid{grid-template-columns:repeat(2,1fr);gap:0 24px}
    .room-faq-grid,.cross-card{grid-template-columns:1fr;gap:32px}
    .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,.room-hero,.gallery,.room-key,.room-content,.amenities-inner,.room-faq,.cross-sell-inner{padding-left:20px;padding-right:20px}
    .price-hint{padding-left:20px;padding-right:20px}
    .room-hero h1{font-size:44px;letter-spacing:-2px}
    .gallery-thumbs{grid-template-columns:repeat(3,1fr)}
    .gallery-thumb:nth-child(4){display:none}
    .gallery-thumb:nth-child(3) .gallery-thumb-more{display:flex}
    .room-meta-row{grid-template-columns:1fr}
    .room-meta-item{border-right:none}
    .room-meta-cta{grid-column:span 1}
    .amenities-grid{grid-template-columns:1fr}
    .cross-card{padding:20px}
    .footer-inner{grid-template-columns:1fr;padding:48px 20px 24px}
    .room-content h2{font-size:30px}
  }

  @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)}}
  }