:root{
  --gb-ink:#151814;
  --gb-muted:#74776f;
  --gb-line:#e6e0d8;
  --gb-soft:#f7f4ee;
  --gb-card:#fffdf8;
  --gb-green:#27451d;
  --gb-green-2:#415d35;
  --gb-blue:#1d73e8;
  --gb-shadow:0 26px 70px rgba(15,17,14,.16);
  --gb-radius:20px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body.gr-page{margin:0;background:#f7f4ee;color:var(--gb-ink);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.gr-page-loader{min-height:100vh;display:flex;gap:14px;align-items:center;justify-content:center;color:#616459;font-weight:700;background:#f7f4ee}
.gr-page-loader__dot{width:16px;height:16px;border-radius:50%;background:#294a22;box-shadow:0 0 0 8px rgba(41,74,34,.11);animation:gbPulse 1.1s infinite ease-in-out}
@keyframes gbPulse{50%{transform:scale(.7);opacity:.55}}
.gb-page{min-height:100vh;background:linear-gradient(180deg,#fff 0,#f7f4ee 40%,#f7f4ee 100%)}
.gb-hero{position:relative;min-height:620px;background-image:linear-gradient(90deg,rgba(0,0,0,.72) 0%,rgba(0,0,0,.34) 45%,rgba(0,0,0,.22) 100%),linear-gradient(180deg,rgba(0,0,0,.24),rgba(0,0,0,.36)),var(--hero);background-size:cover;background-position:center;display:flex;flex-direction:column;overflow:visible}
.gb-hero::after{content:"";position:absolute;inset:auto 0 0;height:190px;background:linear-gradient(0deg,rgba(247,244,238,1) 0%,rgba(247,244,238,0) 100%);pointer-events:none}
.gb-header{position:relative;z-index:5;height:74px;background:rgba(0,0,0,.75);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;padding:0 30px;backdrop-filter:blur(14px);border-bottom:1px solid rgba(255,255,255,.08)}
.gb-nav{display:flex;align-items:center;gap:28px;min-width:0}
.gb-nav a{color:#fff;font-weight:800;font-size:13px;white-space:nowrap;letter-spacing:.01em;opacity:.96}
.gb-nav a:hover{opacity:.72}
.gb-nav--right{justify-content:flex-end;gap:14px}
.gb-logo{width:92px;height:92px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.92);box-shadow:0 10px 30px rgba(0,0,0,.35);align-self:start;transform:translateY(10px);overflow:hidden;border:2px solid rgba(255,255,255,.7)}
.gb-logo img{width:92px;height:92px;object-fit:contain}
.gb-social{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;background:#21ce77;color:#04130b;font-size:10px;font-weight:900}
.gb-phone{color:#fff!important;font-size:15px!important;margin-left:12px}
.gb-top-btn{border:2px solid rgba(255,255,255,.94);height:42px;padding:0 27px;display:flex;align-items:center;justify-content:center;color:#fff!important;font-weight:800!important}
.gb-hero-inner{position:relative;z-index:2;width:min(1180px,calc(100% - 80px));margin:0 auto;flex:1;padding:110px 0 0;display:flex;flex-direction:column;justify-content:center}
.gb-hero-copy{max-width:720px;margin-bottom:62px}
.gb-hero-copy h1{font-size:clamp(44px,6vw,74px);line-height:.98;letter-spacing:-.055em;color:#fff;margin:0 0 24px;font-weight:900}
.gb-hero-copy p{font-size:clamp(19px,2vw,26px);line-height:1.35;color:rgba(255,255,255,.88);margin:0;font-weight:500}
.gb-search-card{position:relative;z-index:4;width:min(1080px,100%);margin:0 auto -58px;background:rgba(255,255,255,.98);border:1px solid rgba(255,255,255,.72);border-radius:18px;box-shadow:0 30px 82px rgba(0,0,0,.24);padding:38px 42px;display:grid;grid-template-columns:1.35fr .98fr 220px;gap:30px;align-items:center}
.gb-field{height:76px;width:100%;border:1px solid #dedede;background:#fff;border-radius:9px;padding:14px 18px;display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;text-align:left;color:#14171d;align-items:center;transition:.2s ease}
.gb-field:hover{border-color:#c9c1b5;box-shadow:0 8px 24px rgba(21,24,20,.06)}
.gb-field span{grid-column:1/2;color:#9a9ba3;font-size:14px;font-weight:600;line-height:1.2}
.gb-field b{grid-column:1/2;font-size:19px;font-weight:500;letter-spacing:-.02em}
.gb-field i{grid-column:2/3;grid-row:1/3;color:#9ca0a9;font-style:normal;display:grid;place-items:center}
.gb-search-btn{height:76px;border:0;border-radius:9px;background:var(--gb-green);color:#fff;font-size:20px;font-weight:700;box-shadow:0 16px 34px rgba(39,69,29,.18);transition:.2s ease}
.gb-search-btn:hover{background:#1d3616;transform:translateY(-1px)}
.gb-field-wrap{position:relative}
.gb-guests-pop{position:absolute;top:calc(100% + 12px);left:0;right:0;z-index:20;background:#fff;border:1px solid #e7e2dc;border-radius:18px;box-shadow:0 22px 60px rgba(0,0,0,.16);padding:16px}
.gb-guest-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid #f0ede8}
.gb-guest-row:last-child{border-bottom:0}
.gb-guest-row span{display:flex;flex-direction:column;gap:3px}
.gb-guest-row small{color:#8b8c86}
.gb-guest-row div{display:flex;align-items:center;gap:12px}
.gb-guest-row button{width:34px;height:34px;border:1px solid #ddd5cb;border-radius:50%;background:#faf8f3;font-weight:900}
.gb-calendar-pop{position:absolute;left:42px;right:42px;top:calc(100% + 16px);z-index:30;background:#fff;border:1px solid rgba(0,0,0,.08);border-radius:24px;box-shadow:0 30px 90px rgba(0,0,0,.24);padding:22px}
.gb-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.gb-cal-head div:first-child{display:flex;flex-direction:column;gap:4px}
.gb-cal-head strong{font-size:22px;letter-spacing:-.03em}
.gb-cal-head span{color:#85847c}
.gb-cal-nav{display:flex;gap:8px}
.gb-cal-nav button{width:42px;height:42px;border-radius:50%;border:1px solid #e2ddd5;background:#faf8f3;font-size:24px}
.gb-cal-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.gb-cal-title{text-transform:capitalize;font-weight:800;margin:0 0 14px;font-size:17px}
.gb-weekdays,.gb-days{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.gb-weekdays span{font-size:12px;color:#918e84;text-align:center;font-weight:800;padding:4px 0}
.gb-day{height:42px;border:0;border-radius:12px;background:#f7f4ee;color:#181a17;font-weight:700;transition:.16s ease}
.gb-day:hover:not(:disabled){background:#e9e2d7}
.gb-day.is-out{opacity:.25}
.gb-day.is-disabled{opacity:.28;text-decoration:line-through}
.gb-day.is-range{background:#e6efe1;color:#27451d}
.gb-day.is-selected{background:#27451d;color:#fff}
.gb-day.is-holiday:not(.is-selected){color:#a36c2a}
.gb-cal-foot{display:flex;justify-content:flex-end;gap:10px;border-top:1px solid #eee8df;margin-top:18px;padding-top:16px}
.gb-cal-foot button{height:44px;border:1px solid #e1d9cf;border-radius:12px;padding:0 18px;background:#fff;font-weight:800}
.gb-cal-foot button:last-child{background:#151714;color:#fff;border-color:#151714}
.gb-catalog{position:relative;z-index:1;width:min(1180px,calc(100% - 80px));margin:0 auto;padding:130px 0 70px}
.gb-section-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:44px}
.gb-section-head h2{font-size:42px;line-height:1.05;letter-spacing:-.045em;margin:0 0 14px;font-weight:900}
.gb-section-head p{font-size:18px;color:#8d8d88;margin:0}
.gb-toolbar{display:flex;align-items:center;gap:18px;margin-bottom:34px}
.gb-toolbar-spacer{flex:1}
.gb-filter-btn,.gb-sort-btn,.gb-view-icons{height:50px;border:1px solid #e3ded7;background:#fff;border-radius:9px;display:flex;align-items:center;gap:12px;padding:0 20px;color:#31342f;font-weight:700;box-shadow:0 5px 18px rgba(24,24,18,.03)}
.gb-filter-btn span{font-size:22px;line-height:1}
.gb-filter-btn i,.gb-sort-btn i{font-style:normal;color:#6f736c}
.gb-sort-btn{min-width:240px;justify-content:space-between}
.gb-view-icons{gap:0;padding:0;overflow:hidden}
.gb-view-icons button{width:50px;height:50px;border:0;background:#fff;font-weight:900;color:#777}
.gb-view-icons button.is-active{color:#151714;background:#fbfaf6}
.gb-cards{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.gb-cabin-card{background:#fff;border:1px solid #e5e0d8;border-radius:11px;overflow:hidden;box-shadow:0 14px 36px rgba(32,28,21,.05);transition:.22s ease;position:relative}
.gb-cabin-card:hover{transform:translateY(-4px);box-shadow:0 24px 55px rgba(32,28,21,.11);border-color:#d3cabf}
.gb-cabin-card.is-picked{box-shadow:0 24px 70px rgba(39,69,29,.18);border-color:#9eb18e}
.gb-card-gallery{position:relative;height:356px;display:grid;grid-template-columns:1.25fr .75fr;grid-template-rows:1fr 1fr;gap:3px;background:#eee;overflow:hidden}
.gb-card-img{width:100%;height:100%;object-fit:cover;display:block}
.gb-card-img--main{grid-row:1/3}
.gb-badge{position:absolute;z-index:2;left:14px;top:14px;background:#314d24;color:#fff;border-radius:8px;padding:9px 13px;font-size:13px;font-weight:800;box-shadow:0 12px 30px rgba(0,0,0,.18)}
.gb-card-body{padding:24px 22px 23px}
.gb-card-body h3{font-size:24px;letter-spacing:-.035em;margin:0 0 20px;font-weight:900}
.gb-amenities{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:18px}
.gb-amenities span{display:flex;flex-direction:column;align-items:center;gap:5px;min-width:0}
.gb-amenities i{font-style:normal;font-size:19px;height:22px;line-height:1}
.gb-amenities em{font-style:normal;font-size:11px;color:#5e615b;text-align:center;white-space:nowrap}
.gb-card-tariff{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:17px}
.gb-card-tariff span{background:#eeeae1;border-radius:8px;padding:7px 11px;font-size:13px;font-weight:800}
.gb-card-tariff small{color:#8a877d;font-weight:700;text-align:right}
.gb-card-body p{min-height:52px;color:#6e706a;font-size:14px;line-height:1.55;margin:0 0 22px}
.gb-unavailable{background:#f7eee9;color:#9b4f2e;border:1px solid #edd4c7;padding:10px 12px;border-radius:10px;font-weight:700;margin-bottom:16px;font-size:13px}
.gb-card-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}
.gb-details{font-weight:900;font-size:15px}
.gb-pick-btn{height:40px;border:1px solid #22391b;background:#22391b;color:#fff;border-radius:999px;padding:0 17px;font-weight:800}
.gb-help{margin-top:38px;background:#fff;border:1px solid #e3ded6;border-radius:12px;min-height:82px;display:grid;grid-template-columns:76px 1fr auto;align-items:center;padding:0 22px;gap:18px}
.gb-help span{font-size:32px;color:#9caa88;text-align:center}
.gb-help div{display:flex;flex-direction:column;gap:5px}
.gb-help b{font-size:17px}
.gb-help small{color:#8d8d88;font-size:14px}
.gb-help a{height:44px;border:1px solid #ded8cf;border-radius:10px;padding:0 22px;display:flex;align-items:center;font-weight:800;background:#fff;box-shadow:0 5px 18px rgba(24,24,18,.04)}
.gb-modal{position:fixed;inset:0;z-index:100;display:grid;place-items:center;padding:28px}
.gb-modal-backdrop{position:absolute;inset:0;background:rgba(10,12,9,.62);backdrop-filter:blur(8px)}
.gb-modal-card{position:relative;width:min(1040px,100%);max-height:calc(100vh - 56px);overflow:auto;background:#fff;border-radius:26px;box-shadow:0 40px 120px rgba(0,0,0,.35);padding:34px}
.gb-modal-close{position:absolute;right:22px;top:20px;width:44px;height:44px;border:0;border-radius:50%;background:#f4f1ea;font-size:28px;line-height:1;color:#2e312c}
.gb-modal-head{padding-right:60px;margin-bottom:25px}
.gb-modal-head span{text-transform:uppercase;color:#78806c;font-size:12px;font-weight:900;letter-spacing:.13em}
.gb-modal-head h2{margin:7px 0 8px;font-size:36px;letter-spacing:-.045em}
.gb-modal-head p{margin:0;color:#6d7069;font-weight:600}
.gb-modal-layout{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:24px}
.gb-modal-form{display:grid;gap:14px}
.gb-modal-form label,.gb-form-row label{display:flex;flex-direction:column;gap:8px;font-size:13px;font-weight:800;color:#56584f}
.gb-modal-form input,.gb-modal-form select,.gb-modal-form textarea{width:100%;border:1px solid #e2ddd5;border-radius:13px;background:#fbfaf7;min-height:52px;padding:0 16px;color:#161814;outline:none}
.gb-modal-form textarea{min-height:92px;padding-top:14px;resize:vertical}
.gb-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.gb-modal-services{display:grid;grid-template-columns:1fr;gap:10px;margin:2px 0}
.gb-modal-services>span{font-size:13px;font-weight:900;color:#56584f}
.gb-modal-services label{border:1px solid #e2ddd5;border-radius:13px;padding:14px 16px;display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;background:#fbfaf7}
.gb-modal-services label.is-active{border-color:#8aaa7f;background:#f0f6ec}
.gb-modal-services input{width:auto;min-height:0}
.gb-modal-services em{font-style:normal;color:#6e7169;font-weight:800}
.gb-modal-summary{background:#f7f4ee;border:1px solid #e7e0d7;border-radius:20px;padding:22px;height:max-content;position:sticky;top:0}
.gb-modal-summary div{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #e5ded3;padding:13px 0;color:#5f625b}
.gb-modal-summary div:first-child{padding-top:0}
.gb-modal-summary div.is-total{border-bottom:0;color:#161814}
.gb-modal-summary div.is-total b{font-size:24px}
.gb-modal-summary p{font-size:12px;line-height:1.45;color:#7d7b72;margin:15px 0}
.gb-submit{width:100%;height:56px;border:0;border-radius:14px;background:#25431c;color:#fff;font-weight:900;font-size:16px}
.gb-submit:disabled{opacity:.6}
.gb-error{display:none;background:#fff0eb;color:#9c4220;border:1px solid #f0c9ba;border-radius:12px;padding:12px;margin-bottom:12px;font-weight:700;font-size:13px}
.gb-error.is-visible{display:block}

@media (max-width: 1100px){
  .gb-header{grid-template-columns:auto 1fr auto;height:auto;padding:14px 18px}
  .gb-logo{width:72px;height:72px;transform:none;order:1}
  .gb-logo img{width:72px;height:72px}
  .gb-nav--left{display:none}
  .gb-nav--right{order:2}
  .gb-phone{display:none}
  .gb-top-btn{display:none}
  .gb-social{width:28px;height:28px}
  .gb-hero{min-height:590px}
  .gb-hero-inner{width:min(100% - 36px,880px);padding-top:84px}
  .gb-search-card{grid-template-columns:1fr;padding:24px;gap:14px;margin-bottom:-44px}
  .gb-calendar-pop{left:18px;right:18px}
  .gb-cal-grid{grid-template-columns:1fr}
  .gb-catalog{width:min(100% - 36px,880px);padding-top:100px}
  .gb-cards{grid-template-columns:1fr}
  .gb-card-gallery{height:330px}
}
@media (max-width: 760px){
  .gb-hero{min-height:620px;background-position:center top}
  .gb-hero-inner{padding-top:62px}
  .gb-hero-copy{margin-bottom:34px}
  .gb-hero-copy h1{font-size:42px}
  .gb-hero-copy p{font-size:18px}
  .gb-field,.gb-search-btn{height:64px}
  .gb-field b{font-size:16px}
  .gb-section-head h2{font-size:32px}
  .gb-toolbar{flex-wrap:wrap}
  .gb-toolbar-spacer{display:none}
  .gb-filter-btn,.gb-sort-btn{width:100%;justify-content:space-between}
  .gb-view-icons{display:none}
  .gb-card-gallery{height:300px}
  .gb-help{grid-template-columns:1fr;text-align:center;padding:22px}
  .gb-help a{justify-content:center}
  .gb-modal{padding:12px}
  .gb-modal-card{padding:22px;border-radius:20px}
  .gb-modal-layout{grid-template-columns:1fr}
  .gb-form-row{grid-template-columns:1fr}
}
@media (max-width: 440px){
  .gb-card-gallery{height:260px}
  .gb-amenities{grid-template-columns:repeat(3,1fr)}
  .gb-header{display:flex;justify-content:space-between}
  .gb-logo{width:64px;height:64px}
  .gb-logo img{width:64px;height:64px}
}

/* === Booking UX fixes: loading state, correct image grid, rich extras === */
.gb-card-gallery{
  height:330px;
  display:grid;
  grid-template-columns:1.18fr .82fr;
  grid-template-rows:1fr 1fr;
  gap:2px;
  background:#ede8de;
}
.gb-card-img{
  min-width:0;
  min-height:0;
  background:#ede8de;
  object-fit:cover;
}
.gb-card-img--main{
  grid-row:1/3;
  grid-column:1/2;
}
.gb-card-gallery .gb-card-img:not(.gb-card-img--main):nth-of-type(2){grid-column:2;grid-row:1}
.gb-card-gallery .gb-card-img:not(.gb-card-img--main):nth-of-type(3){grid-column:2;grid-row:2}
.gb-cards.is-loading{
  opacity:.38;
  filter:blur(1.5px);
  pointer-events:none;
  transform:translateY(2px);
  transition:.25s ease;
}
.gb-availability-loading{
  margin:0 0 22px;
  min-height:104px;
  border:1px solid rgba(47,78,36,.16);
  border-radius:22px;
  background:linear-gradient(135deg,#fffef9 0%,#f1eadf 100%);
  box-shadow:0 24px 60px rgba(38,36,28,.08);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:8px;
  color:#26321f;
  text-align:center;
}
.gb-availability-loading b{font-size:18px;font-weight:900}
.gb-availability-loading span{font-size:13px;color:#74766e}
.gb-spinner{
  width:34px;
  height:34px;
  border-radius:50%;
  border:3px solid rgba(39,69,29,.18);
  border-top-color:#27451d;
  animation:gbSpin .85s linear infinite;
}
@keyframes gbSpin{to{transform:rotate(360deg)}}

.gb-services-head{
  display:flex;
  flex-direction:column;
  gap:4px;
  margin:8px 0 4px;
}
.gb-services-head span{
  font-size:20px;
  line-height:1.2;
  font-weight:900;
  color:#151814;
}
.gb-services-head small{
  color:#77796f;
  font-size:13px;
  line-height:1.45;
}
.gb-service-list{
  display:grid;
  grid-template-columns:1fr;
  gap:12px;
}
.gb-modal-services .gb-service-card{
  position:relative;
  display:grid;
  grid-template-columns:150px minmax(0,1fr) 42px;
  gap:16px;
  align-items:stretch;
  min-height:132px;
  padding:0;
  overflow:hidden;
  border-radius:18px;
  border:1px solid #e5ded4;
  background:#fffdf9;
  box-shadow:0 10px 30px rgba(35,30,22,.05);
  cursor:pointer;
  transition:.2s ease;
}
.gb-modal-services .gb-service-card:hover{
  border-color:#b7c3aa;
  transform:translateY(-1px);
  box-shadow:0 18px 42px rgba(35,30,22,.09);
}
.gb-modal-services .gb-service-card.is-active{
  border-color:#6d8f5e;
  background:linear-gradient(135deg,#f8fbf4 0%,#fffdf9 100%);
  box-shadow:0 18px 46px rgba(39,69,29,.14);
}
.gb-service-card input{
  position:absolute;
  inset:0;
  opacity:0;
  cursor:pointer;
}
.gb-service-card img{
  width:150px;
  height:100%;
  min-height:132px;
  object-fit:cover;
  display:block;
  background:#eee8dc;
}
.gb-service-info{
  padding:18px 0;
  display:flex;
  flex-direction:column;
  min-width:0;
}
.gb-service-info b{
  font-size:20px;
  line-height:1.15;
  font-weight:900;
  color:#161814;
  margin-bottom:8px;
}
.gb-service-info em{
  font-style:normal;
  color:#64685f;
  font-size:13px;
  line-height:1.45;
  font-weight:500;
  margin-bottom:14px;
}
.gb-service-info strong{
  margin-top:auto;
  font-size:18px;
  color:#263e1d;
  font-weight:900;
}
.gb-service-card>i{
  align-self:center;
  justify-self:center;
  width:30px;
  height:30px;
  margin-right:12px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#f1eee8;
  color:#24391b;
  font-style:normal;
  font-weight:900;
}
.gb-service-card.is-active>i{
  background:#27451d;
  color:#fff;
}
.gb-privacy-note{
  display:grid !important;
  grid-template-columns:22px 1fr;
  gap:9px;
  align-items:start;
  border-bottom:0 !important;
  padding:12px 0 6px !important;
  color:#77766f !important;
}
.gb-privacy-note span{
  width:22px;
  height:22px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#e9efe2;
  color:#27451d;
  font-size:12px;
  font-weight:900;
}
.gb-modal-summary .gb-privacy-note p{
  margin:0;
  font-size:12px;
  line-height:1.45;
  color:#77766f;
}
.gb-modal-summary .gb-privacy-note + .gb-error{
  margin-top:10px;
}
.gb-modal-form > .gb-modal-services{
  margin-top:4px;
}

@media (max-width: 760px){
  .gb-card-gallery{height:260px;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}
  .gb-card-img--main{grid-column:1/3;grid-row:1}
  .gb-card-gallery .gb-card-img:not(.gb-card-img--main):nth-of-type(2){grid-column:1;grid-row:2}
  .gb-card-gallery .gb-card-img:not(.gb-card-img--main):nth-of-type(3){grid-column:2;grid-row:2}
  .gb-modal-services .gb-service-card{
    grid-template-columns:112px minmax(0,1fr) 34px;
    min-height:118px;
  }
  .gb-service-card img{width:112px;min-height:118px}
  .gb-service-info{padding:14px 0}
  .gb-service-info b{font-size:17px}
  .gb-service-info em{font-size:12px;line-height:1.35}
  .gb-service-info strong{font-size:15px}
}


/* === Booking UX fixes: working toolbar, wider modal, service scroller === */
.gb-toolbar-item{position:relative;display:flex}
.gb-filter-btn.is-open,.gb-sort-btn.is-open{border-color:#b8c4a9;box-shadow:0 12px 28px rgba(39,69,29,.09);background:#fffdf8}
.gb-menu-pop{
  position:absolute;
  top:calc(100% + 10px);
  left:0;
  z-index:30;
  min-width:230px;
  padding:8px;
  border:1px solid #e1dbd2;
  border-radius:16px;
  background:#fffdf8;
  box-shadow:0 24px 60px rgba(30,27,22,.18);
  display:grid;
  gap:4px;
}
.gb-menu-pop--right{left:auto;right:0}
.gb-menu-pop--wide{min-width:310px;padding:12px}
.gb-menu-pop button{
  width:100%;
  border:0;
  border-radius:11px;
  background:transparent;
  padding:11px 12px;
  text-align:left;
  color:#272a24;
  font-weight:800;
}
.gb-menu-pop button:hover,.gb-menu-pop button.is-active{background:#f2eee6;color:#27451d}
.gb-check-line{display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:flex-start;padding:10px 8px;color:#242823}
.gb-check-line input{margin-top:4px;accent-color:#27451d}
.gb-check-line b{display:block;font-size:14px}
.gb-check-line small{display:block;color:#74776f;margin-top:3px;line-height:1.3}
.gb-check-line.is-disabled{opacity:.55}
.gb-empty-catalog{
  grid-column:1/-1;
  border:1px dashed #d8d0c5;
  border-radius:20px;
  background:#fffdf8;
  padding:34px;
  color:#73786f;
  font-weight:800;
  text-align:center;
}
.gb-cards--list{grid-template-columns:1fr}
.gb-cards--list .gb-cabin-card{display:grid;grid-template-columns:minmax(320px,42%) 1fr}
.gb-cards--list .gb-card-gallery{height:300px}
.gb-cards--list .gb-card-body{align-self:center}
.gb-card-gallery{background:linear-gradient(135deg,#ede8dc,#f8f5ee)}
.gb-card-img{background:#eee8dd}
.gb-modal{padding:18px}
.gb-modal-card{
  width:min(1280px,calc(100vw - 32px));
  max-height:calc(100vh - 36px);
  overflow:hidden;
  display:flex;
  flex-direction:column;
}
.gb-modal-layout{
  grid-template-columns:minmax(0,1fr) 360px;
  min-height:0;
  max-height:calc(100vh - 185px);
  overflow:hidden;
}
.gb-modal-form{
  min-height:0;
  overflow:auto;
  padding-right:10px;
  scrollbar-width:thin;
  scrollbar-color:#c5bdae transparent;
}
.gb-modal-form::-webkit-scrollbar,.gb-service-list::-webkit-scrollbar{width:8px}
.gb-modal-form::-webkit-scrollbar-thumb,.gb-service-list::-webkit-scrollbar-thumb{background:#c5bdae;border-radius:99px}
.gb-modal-summary{position:sticky;top:0;align-self:start;max-height:100%;overflow:auto}
.gb-modal-services{
  border:1px solid #e6ded4;
  border-radius:20px;
  padding:16px;
  background:#fffdf8;
}
.gb-services-head{display:flex;justify-content:space-between;align-items:flex-end;gap:14px;padding:0 2px 12px;border-bottom:1px solid #e8e0d6}
.gb-services-head span{font-size:16px;font-weight:900;color:#1e211d}
.gb-services-head small{max-width:420px;text-align:right;color:#777b71;font-weight:600;line-height:1.35}
.gb-service-list{
  max-height:390px;
  overflow-y:auto;
  padding:14px 7px 2px 0;
}
.gb-modal-services .gb-service-card{
  grid-template-columns:170px minmax(0,1fr) 46px;
  min-height:148px;
}
.gb-service-card img{width:170px;height:148px;object-fit:cover}
.gb-service-info em{line-height:1.35}
.gb-privacy-note{
  gap:12px;
  align-items:flex-start!important;
  justify-content:flex-start!important;
  background:#f3f7ef;
  border:1px solid #dfe8d8!important;
  border-radius:14px;
  padding:12px!important;
  margin:8px 0 12px;
}
.gb-privacy-note span{
  flex:0 0 auto;
  width:26px;
  height:26px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#dcebd4;
  color:#27451d;
  font-weight:900;
}
.gb-privacy-note p{margin:0;color:#5e6559;font-size:12px;line-height:1.35;font-weight:700}
.gb-error:empty{display:none!important}
.gb-error:not(.is-visible){display:none!important}
@media (max-width: 980px){
  .gb-cards--list .gb-cabin-card{display:block}
  .gb-modal-card{width:calc(100vw - 18px);overflow:auto}
  .gb-modal-layout{grid-template-columns:1fr;max-height:none;overflow:visible}
  .gb-modal-form{overflow:visible;max-height:none}
  .gb-service-list{max-height:330px}
  .gb-services-head{display:block}
  .gb-services-head small{text-align:left;margin-top:4px;display:block}
}
@media (max-width: 720px){
  .gb-toolbar{display:grid;grid-template-columns:1fr 1fr;gap:10px}
  .gb-toolbar-spacer{display:none}
  .gb-toolbar-item,.gb-filter-btn,.gb-sort-btn,.gb-view-icons{width:100%}
  .gb-sort-btn{min-width:0}
  .gb-menu-pop{min-width:100%;right:auto}
  .gb-modal-services .gb-service-card{grid-template-columns:112px minmax(0,1fr) 38px;min-height:122px}
  .gb-service-card img{width:112px;height:122px}
}

/* === Unified Barnhouse + pixel-safety pass === */
.gb-page{font-feature-settings:"kern" 1;text-rendering:optimizeLegibility}
.gb-header{min-width:0}
.gb-nav,.gb-nav a,.gb-top-btn,.gb-phone{min-width:0}
.gb-nav a,.gb-top-btn{line-height:1.15}
.gb-toolbar{flex-wrap:wrap;align-items:stretch}
.gb-toolbar-item{min-width:0}
.gb-filter-btn,.gb-sort-btn,.gb-view-icons{min-width:0;max-width:100%}
.gb-filter-btn,.gb-sort-btn{line-height:1.15;white-space:nowrap}
.gb-menu-pop{max-width:min(360px,calc(100vw - 32px));}
.gb-card-body{display:flex;flex-direction:column;min-height:300px}
.gb-card-actions{margin-top:auto}
.gb-card-tariff{flex-wrap:wrap;align-items:flex-start}
.gb-amenities{align-items:start}
.gb-amenities em{white-space:normal;line-height:1.15;min-height:24px}
.gb-pick-btn,.gb-details,.gb-search-btn,.gb-submit{line-height:1.15;white-space:nowrap}
.gb-cards--list .gb-card-body{min-height:0}
.gb-modal-head h2{overflow-wrap:anywhere}
.gb-modal-form input,.gb-modal-form textarea,.gb-modal-form select{font-size:15px}
.gb-modal-summary div{gap:16px}
.gb-modal-summary b{text-align:right}
.gb-service-info{min-width:0}
.gb-service-info b,.gb-service-info em{overflow-wrap:anywhere}
@media (max-width:1320px){
  .gb-nav{gap:16px}.gb-header{padding:0 20px}.gb-top-btn{padding:0 18px}.gb-phone{font-size:14px!important;margin-left:4px}
  .gb-search-card{width:min(1040px,calc(100% - 28px))}
  .gb-catalog{width:min(1120px,calc(100% - 40px))}
}
@media (max-width:1180px){
  .gb-nav--left{gap:14px}.gb-nav a{font-size:12px}.gb-logo{width:76px;height:76px}.gb-logo img{width:76px;height:76px}
}
@media (max-width:920px){
  .gb-toolbar{display:grid;grid-template-columns:1fr 1fr;gap:10px}.gb-toolbar-spacer{display:none}.gb-toolbar-item{width:100%}.gb-filter-btn,.gb-sort-btn,.gb-view-icons{width:100%;justify-content:space-between}.gb-view-icons{display:flex}.gb-view-icons button{flex:1}
  .gb-cards{grid-template-columns:1fr}.gb-cabin-card{max-width:680px;width:100%;margin:0 auto}.gb-modal-layout{grid-template-columns:1fr}.gb-modal-summary{position:relative;top:auto}
}
@media (max-width:560px){
  .gb-toolbar{grid-template-columns:1fr}.gb-search-card{padding:18px;border-radius:16px}.gb-calendar-pop{left:10px;right:10px;padding:14px}.gb-cal-grid{gap:14px}.gb-day{height:38px;border-radius:10px}.gb-modal-card{padding:18px}.gb-modal-head h2{font-size:30px}.gb-service-list{max-height:300px}.gb-modal-services .gb-service-card{grid-template-columns:96px minmax(0,1fr) 32px}.gb-service-card img{width:96px;height:116px}.gb-service-info em{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
}


/* === Full-site audit fixes applied to booking page === */
.gb-page, .gb-page *{min-width:0}
.gb-nav a,.gb-top-btn,.gb-phone,.gb-filter-btn,.gb-sort-btn,.gb-search-btn,.gb-pick-btn,.gb-submit{
  overflow-wrap:anywhere;
  text-wrap:balance;
}
.gb-social svg,.gb-amenities svg{
  display:block;
  width:1em;
  height:1em;
}
.gb-social{
  color:#06150d;
  font-size:15px;
  line-height:1;
}
.gb-amenities span{
  min-width:0;
  overflow:hidden;
}
.gb-amenities i{
  min-height:24px;
  color:#151814;
}
.gb-amenities em{
  display:block;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.gb-cabin-card img,.gb-service-card img{
  content-visibility:auto;
  contain-intrinsic-size:300px 220px;
}
.gb-cabin-card,.gb-modal-card,.gb-search-card{
  transform:translateZ(0);
}
.gb-menu-pop{will-change:transform,opacity}
.gb-cards--list{
  grid-template-columns:1fr;
}
.gb-cards--list .gb-cabin-card{
  display:grid;
  grid-template-columns:420px minmax(0,1fr);
}
.gb-cards--list .gb-card-gallery{
  height:auto;
  min-height:290px;
}
.gb-cards--list .gb-card-body{
  display:flex;
  flex-direction:column;
}
.gb-cards--list .gb-card-actions{
  margin-top:auto;
}
.gb-empty-catalog{
  grid-column:1/-1;
  border:1px dashed #d7cfc4;
  border-radius:18px;
  padding:28px;
  background:#fffdf8;
  color:#6f736a;
  font-weight:800;
}
.gb-error{
  display:block;
  border:1px solid #e6b5ad;
  background:#fff2ef;
  color:#9a2e1f;
  border-radius:12px;
  padding:10px 12px;
  font-weight:800;
  line-height:1.35;
}
.gb-submit[disabled], .gb-search-btn[disabled]{
  opacity:.7;
  pointer-events:none;
}
@media (max-width: 1100px){
  .gb-cards--list .gb-cabin-card{grid-template-columns:1fr}
  .gb-cards--list .gb-card-gallery{height:330px}
  .gb-toolbar{align-items:stretch}
}
@media (max-width: 560px){
  .gb-toolbar{display:grid;grid-template-columns:1fr;gap:10px}
  .gb-toolbar-item,.gb-filter-btn,.gb-sort-btn,.gb-view-icons{width:100%}
  .gb-view-icons{display:flex}
  .gb-view-icons button{flex:1}
  .gb-search-card{border-radius:18px;padding:18px}
  .gb-card-actions{display:grid;grid-template-columns:1fr;gap:10px}
  .gb-pick-btn{width:100%}
}
