*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#F8F6F3;--s:#fff;--sa:#EFECE7;--sb:#E8E4DD;
  --tx:#1C1917;--tm:#78716C;--tl:#A8A29E;
  --acc:#B45309;--acc2:#92400E;--acc-bg:#FEF3C7;--acc-bg2:#FDE68A;
  --teal:#0F766E;--teal2:#115E59;--teal-bg:#CCFBF1;
  --nv:#1C1917;--nv2:#292524;
  --fd:'Source Serif 4',Georgia,serif;
  --fb:'Plus Jakarta Sans',system-ui,sans-serif;
  --mw:1140px;--r:12px;
}
html{scroll-behavior:smooth}
body{font-family:var(--fb);color:var(--tx);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--teal);text-decoration:none}
a:hover{color:var(--teal2)}
ul{list-style:none}

/* ── HEADER ── */
.vs-hdr{background:var(--nv);position:sticky;top:0;z-index:1000;border-bottom:1px solid rgba(255,255,255,.06)}
.vs-hdr-in{max-width:var(--mw);margin:0 auto;padding:0 20px;display:flex;align-items:center;justify-content:space-between;height:56px}
.vs-logo{font-family:var(--fd);font-weight:700;font-size:18px;color:#fff;letter-spacing:-.02em}
.vs-logo span{color:var(--acc-bg2)}
.vs-nav{display:flex;align-items:center;gap:2px}
.vs-nav a{color:rgba(255,255,255,.6);font-size:13px;font-weight:500;padding:6px 12px;border-radius:6px;transition:all .2s;white-space:nowrap}
.vs-nav a:hover,.vs-nav a.act{color:#fff;background:rgba(255,255,255,.08)}
.vs-nav a.act{color:var(--acc-bg2)}
.vs-dd{position:relative}
.vs-dd-btn{color:rgba(255,255,255,.6);font-size:13px;font-weight:500;padding:6px 12px;border-radius:6px;cursor:pointer;background:none;border:none;font-family:var(--fb);display:flex;align-items:center;gap:4px;transition:all .2s}
.vs-dd-btn:hover{color:#fff;background:rgba(255,255,255,.08)}
.vs-dd-btn::after{content:'▾';font-size:10px;opacity:.5}
.vs-dd-menu{display:none;position:absolute;top:100%;left:0;background:var(--nv2);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px 6px 6px;min-width:200px;box-shadow:0 12px 40px rgba(0,0,0,.4);z-index:100}
.vs-dd:hover .vs-dd-menu{display:block}
.vs-dd-menu a{display:block;padding:8px 12px;color:rgba(255,255,255,.6);font-size:13px;border-radius:6px;transition:all .15s}
.vs-dd-menu a:hover{color:#fff;background:rgba(255,255,255,.06)}
.vs-burger{display:none;background:none;border:none;cursor:pointer;padding:8px;color:#fff}
.vs-burger svg{width:22px;height:22px}
.vs-mob{display:none;position:fixed;inset:0;background:var(--nv);z-index:999;padding:20px;overflow-y:auto}
.vs-mob.open{display:flex;flex-direction:column}
.vs-mob-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.vs-mob-close{background:none;border:none;color:#fff;cursor:pointer;padding:8px}
.vs-mob-close svg{width:22px;height:22px}
.vs-mob-nav{display:flex;flex-direction:column;gap:2px}
.vs-mob-nav a{color:rgba(255,255,255,.7);font-size:15px;padding:12px 16px;border-radius:8px;font-weight:500;transition:all .2s}
.vs-mob-nav a:hover,.vs-mob-nav a.act{color:#fff;background:rgba(255,255,255,.06)}
.vs-mob-nav a.act{color:var(--acc-bg2)}
.vs-mob-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--tl);padding:16px 16px 6px;font-weight:600}
@media(max-width:900px){.vs-nav{display:none}.vs-burger{display:block}}

/* ── RELATED PAGES ── */
.vs-rp{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px}
.vs-rp-link{padding:8px 18px;border-radius:100px;border:1px solid var(--sb);background:var(--s);font-size:13px;font-weight:500;color:var(--tm);transition:all .2s}
.vs-rp-link:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-bg)}

/* ── BREADCRUMBS ── */
.vs-bc{background:var(--sa);border-bottom:1px solid var(--sb)}
.vs-bc-in{max-width:var(--mw);margin:0 auto;padding:8px 20px;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--tl);flex-wrap:wrap}
.vs-bc-in a{color:var(--tm);transition:color .15s}
.vs-bc-in a:hover{color:var(--teal)}
.vs-bc-sep{color:var(--tl);user-select:none}
/* Hero breadcrumb */
.sp-bc{display:flex;align-items:center;gap:6px;font-size:12px;color:rgba(255,255,255,.45);margin-bottom:14px;flex-wrap:wrap}
.sp-bc a{color:rgba(255,255,255,.45);transition:color .15s}
.sp-bc a:hover{color:#fff}
.sp-bc-sep{color:rgba(255,255,255,.2)}
.sp-bc-cur{color:rgba(255,255,255,.75)}

/* ── HERO ── */
.vs-hero{background:var(--nv);color:#fff;padding:44px 20px 36px;position:relative;overflow:hidden}
.vs-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 15% 60%,rgba(180,83,9,.06),transparent 55%),radial-gradient(ellipse at 85% 30%,rgba(15,118,110,.04),transparent 50%)}
.vs-hero-in{position:relative;max-width:var(--mw);margin:0 auto}
.vs-bdg{display:inline-flex;align-items:center;gap:5px;background:rgba(180,83,9,.12);border:1px solid rgba(180,83,9,.2);padding:4px 12px;border-radius:100px;font-size:11px;letter-spacing:.02em;text-transform:uppercase;color:var(--acc-bg2);margin-bottom:14px}
.vs-hero h1{font-family:var(--fd);font-size:clamp(24px,4vw,36px);font-weight:700;line-height:1.2;margin-bottom:10px;letter-spacing:-.02em}
.vs-hero h1 em{font-style:italic;color:var(--acc-bg2)}
.vs-hero-sub{font-size:15px;color:rgba(255,255,255,.5);max-width:620px;line-height:1.7}
.vs-stats{display:flex;flex-wrap:wrap;gap:20px;margin-top:18px}
.vs-st b{display:block;font-size:17px;font-family:var(--fd);color:var(--acc-bg2);font-weight:600}
.vs-st span{font-size:10px;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.04em}

/* ── QUICK ANSWER ── */
.vs-qa-w{max-width:var(--mw);margin:0 auto;padding:0 20px}
.vs-qa{background:var(--s);border:1px solid var(--sb);border-radius:var(--r);padding:20px 22px;margin-top:-20px;position:relative;z-index:2;box-shadow:0 2px 12px rgba(0,0,0,.04)}
.vs-qa p{color:var(--tm);font-size:14px;line-height:1.7;margin:0}
.vs-qa strong{color:var(--tx)}

/* ── TOC ── */
.vs-toc{max-width:var(--mw);margin:24px auto;padding:0 20px}
.vs-toc-in{display:flex;flex-wrap:wrap;gap:5px;padding:14px 18px;background:var(--s);border:1px solid var(--sb);border-radius:var(--r)}
.vs-toc-in a{padding:5px 12px;border-radius:100px;background:var(--sa);font-size:12px;font-weight:500;color:var(--tm);transition:all .2s}
.vs-toc-in a:hover{background:var(--teal);color:#fff}

/* ── SECTIONS ── */
.vs-sec{max-width:var(--mw);margin:0 auto;padding:40px 20px}
.vs-lb{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--acc);font-weight:600;margin-bottom:6px;display:block}
.vs-sec h2{font-family:var(--fd);font-size:clamp(20px,2.5vw,26px);font-weight:700;color:var(--tx);margin-bottom:6px;letter-spacing:-.01em}
.vs-sec>p{color:var(--tm);font-size:14px;max-width:620px;margin-bottom:22px}
.vs-sec h3{font-family:var(--fd);font-size:17px;font-weight:600;color:var(--tx);margin:28px 0 8px}
.vs-dv{max-width:var(--mw);height:1px;background:var(--sb);margin:0 auto}

/* ── TAGS ── */
.vs-tag{display:inline-block;padding:3px 9px;border-radius:100px;font-size:10px;font-weight:600;letter-spacing:.02em;text-transform:uppercase;white-space:nowrap}
.vs-tag-price{background:var(--teal-bg);color:var(--teal2)}
.vs-tag-space{background:var(--acc-bg);color:var(--acc2)}
.vs-tag-guest{background:#EDE9FE;color:#6D28D9}
.vs-tag-kitch{background:#DBEAFE;color:#1D4ED8}
.vs-tag-bud{background:var(--teal-bg);color:var(--teal2)}
.vs-tag-prem{background:var(--acc-bg);color:var(--acc2)}

/* ── FILTERS ── */
.vs-fil{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.vs-fb{padding:6px 14px;border-radius:100px;border:1px solid var(--sb);background:var(--s);font-family:var(--fb);font-size:12px;cursor:pointer;color:var(--tm);transition:all .15s}
.vs-fb:hover{border-color:var(--teal);color:var(--teal)}
.vs-fb.act{background:var(--teal);color:#fff;border-color:var(--teal)}
.vs-cnt{font-size:11px;color:var(--tl);margin-bottom:12px}

/* ── TABLE ── */
.vs-tw{overflow-x:auto;border-radius:var(--r);border:1px solid var(--sb);background:var(--s);-webkit-overflow-scrolling:touch}
.vs-tw table{width:100%;min-width:720px;border-collapse:collapse;font-size:13px}
.vs-tw thead{background:var(--nv);color:#fff}
.vs-tw th{padding:10px 11px;text-align:left;font-weight:600;font-size:10px;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}
.vs-tw th.srt{cursor:pointer;user-select:none}
.vs-tw th.srt:hover{color:var(--acc-bg2)}
.vs-tw td{padding:10px 11px;border-top:1px solid var(--sa);vertical-align:middle}
.vs-tw tbody tr{transition:background .12s}
.vs-tw tbody tr:hover{background:var(--sa)}
.vs-sn{font-weight:600;color:var(--tx);display:block;line-height:1.3;font-size:13px}
.vs-sn a{color:var(--tx)}
.vs-sn a:hover{color:var(--teal)}
.vs-sh{font-size:11px;color:var(--tm)}
.vs-pls{display:flex;flex-wrap:wrap;gap:3px}
.vs-pl{padding:2px 6px;border-radius:4px;background:var(--sa);font-size:10px;color:var(--tm);white-space:nowrap}
.vs-pr{font-weight:700;color:var(--teal2);font-size:13px;white-space:nowrap}
.vs-pr small{display:block;font-weight:400;color:var(--tl);font-size:10px}
.vs-pr-na{color:var(--tl);font-size:12px;font-style:italic}
.vs-cta{display:inline-block;padding:6px 14px;border-radius:100px;background:var(--acc);color:#fff!important;font-size:11px;font-weight:600;transition:all .2s;white-space:nowrap;text-decoration:none!important;cursor:pointer}
.vs-cta:hover{background:var(--acc2);transform:translateY(-1px)}

/* ── SUITE CARDS ── */
.vs-cards{display:grid;gap:20px;margin-bottom:8px}
.vs-card{background:var(--s);border-radius:14px;border:1px solid var(--sb);overflow:hidden;transition:box-shadow .3s,transform .2s}
.vs-card:hover{box-shadow:0 8px 32px rgba(0,0,0,.07);transform:translateY(-2px)}
/* Top: image + info panel */
.vs-card-top{display:grid;grid-template-columns:340px 1fr}
.vs-card-img{position:relative;overflow:hidden;background:var(--nv);min-height:280px}
.vs-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.vs-card:hover .vs-card-img img{transform:scale(1.04)}
.vs-card-img .vs-tag{position:absolute;top:12px;left:12px;box-shadow:0 1px 4px rgba(0,0,0,.2)}
/* Info panel */
.vs-card-bd{padding:24px 26px;display:flex;flex-direction:column}
.vs-card-hotel{font-size:11px;font-weight:600;color:var(--tm);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}
.vs-card-bd h3{font-size:20px;font-family:var(--fd);color:var(--tx);line-height:1.25;margin:0 0 16px}
.vs-card-bd h3 span{display:none}
/* Stats row */
.vs-sps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;background:var(--sa);border-radius:8px;overflow:hidden;margin-bottom:16px}
.vs-sp{text-align:center;padding:12px 8px;position:relative}
.vs-sp:not(:last-child)::after{content:'';position:absolute;right:0;top:20%;height:60%;width:1px;background:var(--sb)}
.vs-sp svg{display:block;margin:0 auto 5px;width:18px;height:18px;color:var(--acc)}
.vs-sp b{display:block;font-size:15px;font-weight:700;color:var(--tx)}
.vs-sp span{font-size:10px;color:var(--tm);text-transform:uppercase;letter-spacing:.04em;margin-top:2px}
/* Highlights */
.vs-fts{display:flex;flex-direction:column;gap:7px;font-size:13px;color:var(--tx)}
.vs-fts li{padding-left:20px;position:relative;line-height:1.45}
.vs-fts li::before{content:'';position:absolute;left:0;top:5px;width:14px;height:14px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23047857' stroke-width='2.5'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") no-repeat center/contain}
/* Description text — always visible */
.vs-card-desc{border-top:1px solid var(--sb);padding:18px 26px;font-size:13.5px;line-height:1.75;color:var(--tm)}
.vs-card-desc p{margin-bottom:10px}
.vs-card-desc p:last-child{margin-bottom:0}
.vs-card-desc strong{color:var(--tx);font-weight:600}
/* Read more button — тільки на мобілці */
.vs-card-toggle{border-top:1px solid var(--sb);display:none;justify-content:center}
.vs-toggle-btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;background:none;border:none;cursor:pointer;font-family:var(--fb);font-size:13px;font-weight:500;color:var(--teal2);transition:color .2s}
.vs-toggle-btn:hover{color:var(--acc)}
.vs-toggle-btn svg{width:14px;height:14px;transition:transform .3s}
.vs-toggle-btn.open svg{transform:rotate(180deg)}
/* Footer: price + CTA */
.vs-card-bt{display:flex;justify-content:space-between;align-items:center;padding:16px 26px;border-top:1px solid var(--sb);background:var(--sa);flex-wrap:wrap;gap:10px}
.vs-pm{font-size:13px;color:var(--tm);text-transform:uppercase;letter-spacing:.04em}
.vs-pm b{display:block;font-family:var(--fd);font-size:26px;color:var(--acc);line-height:1.1;font-weight:700}
.vs-pn{font-size:10px;color:var(--tm)}
.vs-cta-lg{display:inline-flex;align-items:center;gap:6px;padding:12px 24px;border-radius:8px;background:var(--acc);color:#fff!important;font-weight:600;font-size:14px;transition:all .2s;text-decoration:none!important;box-shadow:0 2px 8px rgba(180,83,9,.2);cursor:pointer}
.vs-cta-lg:hover{background:var(--acc2);transform:translateY(-1px);box-shadow:0 4px 14px rgba(180,83,9,.3)}
.vs-cta-lg svg{width:15px;height:15px;transition:transform .2s}
.vs-cta-lg:hover svg{transform:translateX(3px)}

/* ── CATEGORIES ── */
.vs-ucg{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.vs-uc{background:var(--s);border:1px solid var(--sb);border-radius:var(--r);padding:18px;transition:box-shadow .2s}
.vs-uc:hover{box-shadow:0 3px 12px rgba(0,0,0,.04)}
.vs-uc-i{font-size:20px;margin-bottom:6px}
.vs-uc h3{font-size:15px;margin-bottom:4px}
.vs-uc p{font-size:12px;color:var(--tm);margin-bottom:10px;line-height:1.5}
.vs-pk{display:flex;justify-content:space-between;align-items:center;padding:7px 10px;background:var(--sa);border-radius:6px;font-size:12px;margin-bottom:4px}
.vs-pk b{font-weight:600;color:var(--tx)}
.vs-pk em{font-style:normal;color:var(--teal2);font-weight:600;font-size:11px}

/* intro під h2 секції — на всю ширину */
.vs-sec-intro{color:var(--tm);line-height:1.75;font-size:15px;margin-bottom:16px;margin-top:-4px}
/* ── GUIDE / CALLOUT / VERSUS ── */
.vs-gd h3{margin-top:24px;margin-bottom:6px}
.vs-gd p{color:var(--tm);line-height:1.75;margin-bottom:12px;font-size:14px}
.vs-co{background:var(--teal-bg);border-left:3px solid var(--teal);padding:14px 18px;border-radius:0 8px 8px 0;margin:16px 0;font-size:13px;color:var(--teal2);line-height:1.6}
.vs-vs{display:grid;grid-template-columns:1fr 40px 1fr;gap:0;margin:16px 0;align-items:stretch}
.vs-vb{background:var(--s);border:1px solid var(--sb);border-radius:10px;padding:14px}
.vs-vb h4{font-family:var(--fd);font-size:14px;margin-bottom:6px}
.vs-vb li{font-size:12px;color:var(--tm);padding:2px 0 2px 14px;position:relative;list-style:none}
.vs-vb li::before{content:'•';position:absolute;left:0;color:var(--teal);font-weight:700}
.vs-vm{display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--tl);font-size:12px}

/* ── FAQ ── */
.vs-faq{max-width:700px;margin:0 auto}
.vs-fi{border:1px solid var(--sb);border-radius:10px;background:var(--s);margin-bottom:6px;overflow:hidden}
.vs-fi:hover{box-shadow:0 1px 4px rgba(0,0,0,.03)}
.vs-fq{padding:14px 16px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;font-weight:600;font-size:14px;user-select:none}
.vs-fq::after{content:'+';font-size:18px;color:var(--tl);transition:transform .3s;flex-shrink:0}
.vs-fi.open .vs-fq::after{transform:rotate(45deg);color:var(--teal)}
.vs-fa{max-height:0;overflow:hidden;transition:max-height .4s ease}
.vs-fi.open .vs-fa{max-height:600px}
.vs-fa p{padding:0 16px 14px;color:var(--tm);font-size:13px;line-height:1.7}

/* ── FOOTER ── */
.vs-ftr{background:var(--nv);color:rgba(255,255,255,.4);padding:40px 20px;margin-top:48px}
.vs-ftr-in{max-width:var(--mw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1fr;gap:32px}
.vs-ftr h4{font-family:var(--fd);font-size:14px;color:rgba(255,255,255,.8);margin-bottom:10px}
.vs-ftr a{color:rgba(255,255,255,.4);font-size:13px;display:block;padding:3px 0;transition:color .15s}
.vs-ftr a:hover{color:var(--acc-bg2)}
.vs-ftr-btm{max-width:var(--mw);margin:0 auto;padding-top:20px;border-top:1px solid rgba(255,255,255,.06);margin-top:24px;font-size:11px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}

/* ── BOOKING FORM (hero) ── */
.vs-book{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:18px 22px;margin-top:22px;display:grid;grid-template-columns:1fr 1fr 1fr auto;gap:14px;align-items:end;max-width:100%}
.vs-book-field{display:flex;flex-direction:column;gap:4px}
.vs-book-field label{font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:rgba(255,255,255,.4);font-weight:600}
.vs-book-wrap{position:relative;cursor:pointer}
.vs-book-wrap input{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:11px 14px 11px 38px;color:#fff;font-family:var(--fb);font-size:14px;outline:none;transition:border-color .2s;width:100%;cursor:pointer}
.vs-book-wrap input:focus{border-color:var(--acc-bg2)}
.vs-book-wrap input::-webkit-calendar-picker-indicator{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}
.vs-book-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:rgba(255,255,255,.4);pointer-events:none}
.vs-book-wrap select{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:11px 14px 11px 38px;color:#fff;font-family:var(--fb);font-size:14px;outline:none;width:100%;cursor:pointer;-webkit-appearance:none;appearance:none}
.vs-book-wrap select option{background:var(--nv);color:#fff}
.vs-book-btn{padding:11px 28px;border-radius:100px;background:var(--acc);color:#fff;border:none;font-family:var(--fb);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;box-shadow:0 2px 8px rgba(180,83,9,.3);height:44px}
.vs-book-btn:hover{background:var(--acc2);transform:translateY(-1px);box-shadow:0 4px 14px rgba(180,83,9,.35)}

/* ── MOBILE TABLE → CARDS ── */
.vs-mcards{display:none}
.vs-mcard{background:var(--s);border:1px solid var(--sb);border-radius:10px;padding:14px;margin-bottom:8px;display:grid;grid-template-columns:1fr auto;gap:8px;align-items:center}
.vs-mcard-info{display:flex;flex-direction:column;gap:3px}
.vs-mcard-name{font-weight:600;font-size:14px;color:var(--tx)}
.vs-mcard-hotel{font-size:11px;color:var(--tm)}
.vs-mcard-specs{display:flex;gap:8px;font-size:11px;color:var(--tm);flex-wrap:wrap}
.vs-mcard-specs b{color:var(--tx);font-weight:600}
.vs-mcard-tags{display:flex;gap:3px;flex-wrap:wrap;margin-top:2px}
.vs-mcard-right{text-align:right;display:flex;flex-direction:column;align-items:end;gap:6px}
.vs-mcard-pr{font-weight:700;color:var(--teal2);font-size:14px;font-family:var(--fd)}
.vs-mcard-pr-na{color:var(--tl);font-size:12px;font-style:italic}

/* ── STICKY MOBILE BOOKING BAR ── */
.vs-sticky{display:none}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .vs-hero{padding:32px 16px 28px}
  .vs-stats{gap:14px}
  .vs-st b{font-size:15px}
  .vs-qa-w{padding:0 16px}
  .vs-qa{padding:14px 16px}
  .vs-toc{margin:16px 16px}
  .vs-toc-in{padding:12px 14px}
  .vs-toc-in a{font-size:11px;padding:4px 10px}
  .vs-sec{padding:28px 16px}
  .vs-fil{flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .vs-fil::-webkit-scrollbar{display:none}
  .vs-fb{flex-shrink:0;font-size:11px;padding:5px 12px}
  .vs-card-top{grid-template-columns:1fr}
  .vs-card-img{min-height:200px}
  .vs-card-bd{padding:14px 16px}
  .vs-card-bd h3{font-size:17px}
  /* Stats: всі три в один рядок — minmax(0) не дає контенту розтягувати колонку */
  .vs-sps{grid-template-columns:repeat(3,minmax(0,1fr))}
  .vs-sp{padding:8px 2px;min-width:0}
  .vs-sp svg{width:14px;height:14px;margin-bottom:3px}
  .vs-sp b{font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
  .vs-sp span{font-size:9px}
  /* Опис на мобілці: прихований, розкривається кнопкою */
  .vs-card-desc{display:none;padding:12px 16px}
  .vs-card-desc.open{display:block}
  .vs-card-toggle{display:flex}
  .vs-card-bt{padding:12px 16px}
  .vs-cta-lg{font-size:13px;padding:10px 18px}
  .vs-ucg{grid-template-columns:1fr}
  .vs-gd p{font-size:13px}
  .vs-vs{grid-template-columns:1fr;gap:8px}
  .vs-vm{padding:2px 0}
  .vs-fq{font-size:13px;padding:12px 14px}
  .vs-fa p{font-size:12px;padding:0 14px 12px}
  .vs-ftr-in{grid-template-columns:1fr;gap:20px}
  .vs-book{grid-template-columns:1fr 1fr;padding:14px 16px;gap:10px}
  .vs-book-wrap input,.vs-book-wrap select{padding:9px 12px 9px 34px;font-size:13px}
  .vs-book-btn{grid-column:1/-1;height:40px;font-size:13px}
  .vs-tw{display:none}
  .vs-mcards{display:block}
  .vs-sticky{display:flex;position:fixed;bottom:0;left:0;right:0;z-index:998;background:var(--nv);border-top:1px solid rgba(255,255,255,.1);padding:8px 12px;gap:6px;align-items:center;box-shadow:0 -4px 20px rgba(0,0,0,.25)}
  .vs-sticky input{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.12);border-radius:6px;padding:8px 8px;color:#fff;font-family:var(--fb);font-size:11px;outline:none;width:100%;min-width:0}
  .vs-sticky input::-webkit-calendar-picker-indicator{position:absolute;inset:0;width:100%;height:100%;opacity:0;cursor:pointer}
  .vs-sticky-btn{padding:8px 16px;border-radius:100px;background:var(--acc);color:#fff;border:none;font-family:var(--fb);font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0}
  body{padding-bottom:60px}
}
@media(max-width:480px){
  .vs-hero h1{font-size:22px}
  .vs-hero-sub{font-size:13px}
  .vs-card-img{min-height:140px}
  .vs-sp b{font-size:13px}
  .vs-sps{grid-template-columns:repeat(2,1fr)}
}

/* ── SUITE SINGLE PAGE  ── */
.sp-hero{background-size:cover;background-position:center}
.sp-hero::before{background:linear-gradient(105deg,rgba(28,25,23,.92) 38%,rgba(28,25,23,.55) 75%,rgba(28,25,23,.3) 100%)!important}
.sp-hotel-name{display:flex;align-items:center;gap:6px;font-size:14px;color:rgba(255,255,255,.55);margin-bottom:16px}
.sp-hotel-name svg{width:13px;height:13px;flex-shrink:0;opacity:.6}
.sp-gallery-w{max-width:var(--mw);margin:0 auto;padding:28px 20px 0}
.sp-gallery{display:grid;grid-template-columns:2fr 1fr;gap:5px;border-radius:var(--r);overflow:hidden}
.sp-gallery-main{position:relative;background:var(--nv);overflow:hidden;aspect-ratio:16/9}
.sp-gallery-main img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.sp-gallery-main:hover img{transform:scale(1.03)}
.sp-gallery-side{display:grid;grid-template-rows:repeat(2,1fr);gap:5px}
.sp-gallery-thumb{background:var(--nv);overflow:hidden;cursor:pointer;position:relative}
.sp-gallery-thumb img{width:100%;height:100%;object-fit:cover;transition:opacity .2s}
.sp-gallery-thumb:hover img{opacity:.85}
.sp-gallery-thumb.sp-gallery-more::after{content:attr(data-more);position:absolute;inset:0;background:rgba(28,25,23,.62);display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;font-weight:600;font-family:var(--fb)}
.sp-ph{background:var(--sa);display:flex;align-items:center;justify-content:center;color:var(--tl);font-size:12px;min-height:180px}
.sp-layout{display:grid;grid-template-columns:1fr 320px;gap:36px;align-items:start}
.sp-sidebar{position:sticky;top:72px;display:flex;flex-direction:column;gap:12px}
.sp-specs{background:var(--s);border:1px solid var(--sb);border-radius:var(--r);padding:20px}
.sp-specs h4{font-family:var(--fd);font-size:15px;font-weight:600;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--sb)}
.sp-spec-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--sa);font-size:13px}
.sp-spec-row:last-child{border-bottom:none;padding-bottom:0}
.sp-spec-row span{color:var(--tm)}
.sp-spec-row b{font-weight:600;color:var(--tx)}
.sp-tags{display:flex;flex-wrap:wrap;gap:5px;padding:0 20px 20px}
.sp-rooms{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}
.sp-room{background:var(--s);border:1px solid var(--sb);border-radius:10px;padding:16px}
.sp-room-icon{font-size:22px;margin-bottom:8px}
.sp-room h4{font-family:var(--fd);font-size:14px;font-weight:600;margin-bottom:5px}
.sp-room p{font-size:12px;color:var(--tm);line-height:1.55}
.sp-amenities{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:7px}
.sp-amenity{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--tx);padding:9px 12px;background:var(--s);border-radius:8px;border:1px solid var(--sa)}
.sp-amenity svg{width:14px;height:14px;color:var(--teal);flex-shrink:0}
.sp-hotel-card{display:grid;grid-template-columns:260px 1fr;background:var(--s);border:1px solid var(--sb);border-radius:var(--r);overflow:hidden}
.sp-hotel-photo{background:var(--nv);min-height:190px}
.sp-hotel-photo img{width:100%;height:100%;object-fit:cover}
.sp-hotel-body{padding:20px 22px}
.sp-hotel-body p{font-size:13px;color:var(--tm);line-height:1.75;margin-bottom:12px}
.sp-hotel-pills{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}
.sp-hotel-pill{padding:4px 10px;background:var(--sa);border-radius:100px;font-size:11px;color:var(--tm)}
.sp-related{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.sp-rel{background:var(--s);border:1px solid var(--sb);border-radius:var(--r);overflow:hidden;transition:box-shadow .25s,transform .2s}
.sp-rel:hover{box-shadow:0 6px 24px rgba(0,0,0,.07);transform:translateY(-2px)}
.sp-rel-img{height:145px;overflow:hidden;background:var(--nv)}
.sp-rel-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.sp-rel:hover .sp-rel-img img{transform:scale(1.05)}
.sp-rel-body{padding:12px 14px}
.sp-rel-hotel{font-size:10px;font-weight:600;color:var(--tm);text-transform:uppercase;letter-spacing:.06em;margin-bottom:4px}
.sp-rel-name{font-family:var(--fd);font-size:13px;font-weight:600;color:var(--tx);line-height:1.3;margin-bottom:8px}
.sp-rel-name a{color:inherit;text-decoration:none}
.sp-rel-name a:hover{color:var(--acc)}
.sp-rel-specs{display:flex;gap:8px;font-size:11px;color:var(--tm)}
.sp-rel-footer{display:flex;justify-content:space-between;align-items:center;padding:9px 14px;background:var(--sa);border-top:1px solid var(--sb)}
.sp-rel-pr{font-weight:700;color:var(--teal2);font-size:13px;font-family:var(--fd)}
@media(max-width:900px){.sp-related{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){.sp-gallery{grid-template-columns:1fr}.sp-gallery-side{grid-template-rows:auto;grid-template-columns:repeat(2,1fr);grid-row:2}.sp-gallery-main{aspect-ratio:4/3}.sp-layout{grid-template-columns:1fr}.sp-sidebar{position:static}.sp-hotel-card{grid-template-columns:1fr}.sp-hotel-photo{min-height:160px}.sp-hotel-body{padding:16px}}
@media(max-width:480px){.sp-related{grid-template-columns:1fr}.sp-rooms{grid-template-columns:repeat(2,1fr)}.sp-amenities{grid-template-columns:1fr}}

