/* SaaS Site Factory v1 – Traveler's Tree style kernel */

:root{
  --ibe-bg:#FBFBF8;
  --ibe-text:#1F2A3D;
  --ibe-muted:#7A7A7A;
  --ibe-line:rgba(64,64,64,.18);
  --ibe-line-strong:rgba(64,64,64,.45);
  --ibe-cta:#2F2F2F;
  --ibe-cta-text:#FBFBF8;
  --ibe-card:#FBFBF8;
  --ibe-radius:16px;
  --ibe-font:Raleway, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--ibe-bg);color:var(--ibe-text);font-family:var(--ibe-font);font-weight:400}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.site-header{
  position:sticky;top:0;z-index:50;background:rgba(251,251,248,.92);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(64,64,64,.08);
}
.site-nav{
  max-width:1140px;margin:0 auto;height:92px;padding:4px 24px;
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:20px;
}
.nav-left,.nav-right{display:flex;align-items:center;gap:28px;font-size:14px;color:#4B5563}
.nav-right{justify-content:flex-end}
.brand{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;min-width:260px;height:100%;overflow:hidden}
.brand img,.brand-logo{width:var(--site-logo-desktop-width,190px);height:var(--site-logo-desktop-height,78px);object-fit:contain;object-position:center;display:block}
.brand-name{font-size:20px;letter-spacing:.01em;color:var(--ibe-text)}
.nav-cta{
  border:1px solid var(--ibe-line-strong);border-radius:6px;padding:11px 26px;
  letter-spacing:.18em;text-transform:uppercase;font-size:11px;color:#404040;
  transition:background-color .22s ease,color .22s ease,border-color .22s ease,transform .22s ease;
}
.nav-cta:hover,
.nav-cta:focus-visible{
  background:#2F2F2F;
  color:#F3EEE7;
  border-color:#2F2F2F;
  outline:none;
}
.nav-cta:active{transform:translateY(1px)}

.hero{
  min-height:calc(100svh - 92px);display:flex;align-items:center;justify-content:center;
  padding:96px 24px;text-align:center;
}
.hero-inner{max-width:860px}
.eyebrow{letter-spacing:.18em;text-transform:uppercase;font-size:12px;color:var(--ibe-muted);margin-bottom:28px}
.hero h1{font-size:clamp(38px,6vw,78px);font-weight:400;line-height:1.08;margin:0 0 28px}
.hero p{font-size:clamp(16px,2vw,22px);line-height:1.6;color:#586174;margin:0 auto 36px;max-width:720px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 22px;border-radius:10px;border:1px solid var(--ibe-cta);
  background:var(--ibe-cta);color:var(--ibe-cta-text);
  letter-spacing:.14em;text-transform:uppercase;font-size:12px;cursor:pointer;
}
.btn.secondary{background:transparent;color:var(--ibe-text);border-color:var(--ibe-line-strong)}
.section{max-width:1140px;margin:0 auto;padding:72px 24px}
.section.center{text-align:center}
.section h1,.section h2{font-weight:400;margin:0 0 16px}
.section h1{font-size:44px}
.section h2{font-size:34px}
.section p.lead{color:var(--ibe-muted);font-size:17px;line-height:1.65;max-width:760px;margin:0 auto 32px}

.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:36px}
.room-card,.ibe-offer-card,.ibe-card{
  border:1px solid var(--ibe-line);border-radius:var(--ibe-radius);
  background:var(--ibe-card);overflow:hidden;
}
.room-card-body{padding:18px}
.room-card h3{font-size:21px;font-weight:400;margin:0 0 8px}
.room-card p{font-size:14px;line-height:1.6;color:#606874;margin:0}
.room-card img{aspect-ratio:4/3;width:100%;object-fit:cover}

.ibe-wrap{max-width:1140px;margin:0 auto;padding:70px 24px 60px}
.ibe-title{text-align:center;margin-bottom:44px}
.ibe-title h1{font-weight:400;font-size:clamp(34px,4vw,46px);margin:0 0 14px}
.ibe-title p{color:var(--ibe-muted);font-size:13px;margin:0}

.book-panel{max-width:760px;margin:0 auto;border:1px solid var(--ibe-line);border-radius:18px;padding:24px;background:var(--ibe-card)}
.book-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.ibe-field label{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.14em;color:var(--ibe-muted);margin:0 0 7px}
.ibe-field input,.ibe-field select,.ibe-field textarea{
  width:100%;border:1px solid rgba(64,64,64,.22);background:#fff;border-radius:10px;
  padding:12px 13px;font-size:15px;color:#404040;font-family:inherit;
}
.ibe-field textarea{min-height:96px;resize:vertical}
.book-actions{margin-top:18px;display:flex;justify-content:flex-end}

.ibe-offers{display:flex;flex-direction:column;gap:20px;max-width:980px;margin:0 auto}
.ibe-offer-card{padding:18px;position:relative}
.ibe-offer-row{display:grid;grid-template-columns:320px 1fr;gap:18px;align-items:start}
.ibe-offer-media{border-radius:12px;overflow:hidden;background:#eee;aspect-ratio:4/3}
.ibe-offer-media img{width:100%;height:100%;object-fit:cover}
.ibe-offer-copy h3{font-size:21px;font-weight:400;margin:0 0 8px}
.ibe-offer-copy .sub{font-size:13px;color:var(--ibe-muted);margin-bottom:12px}
.ibe-offer-copy .desc{font-size:15px;line-height:1.55;color:#4d5562;margin-bottom:24px}
.rate-label{letter-spacing:.18em;text-transform:uppercase;font-size:11px;color:var(--ibe-muted);margin-bottom:8px}
.rate{font-size:15px;margin-bottom:14px;color:#24334A}
.offer-badge{
  position:absolute;right:18px;top:18px;border:1px solid rgba(171,132,72,.45);
  border-radius:999px;padding:4px 8px;font-size:11px;color:#9A6A2D;background:rgba(255,255,255,.55);
}

.reserve-grid{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(320px,.8fr);gap:22px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .full{grid-column:1/-1}
.summary-line{display:flex;justify-content:space-between;border-bottom:1px solid rgba(64,64,64,.12);padding:10px 0;font-size:14px}
.summary-line strong{font-weight:500}
.notice{border:1px solid rgba(176,0,32,.22);background:rgba(176,0,32,.04);color:#8A1F2D;border-radius:12px;padding:16px;line-height:1.5}
.ok-notice{border-color:rgba(24,120,68,.22);background:rgba(24,120,68,.05);color:#187844}
.loading{color:var(--ibe-muted);text-align:center;padding:40px 0}

.kln-sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:999999;display:none;
  justify-content:center;padding:10px 14px calc(10px + env(safe-area-inset-bottom));
  background:rgba(251,251,248,.86);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-top:1px solid rgba(64,64,64,.14);
}
.kln-sticky-btn{
  width:min(520px,100%);text-align:center;padding:14px 18px;border-radius:12px;
  background:#2F2F2F;color:#FBFBF8;border:1px solid #2F2F2F;
  letter-spacing:.14em;text-transform:uppercase;font-size:12px;
}

@media (max-width:900px){
  .site-nav{height:78px;grid-template-columns:1fr auto;gap:12px}
  .brand{align-items:flex-start;min-width:0}
  .nav-left{display:none}
  .nav-right a:not(.nav-cta){display:none}
  .brand-name{font-size:18px}
  .card-grid{grid-template-columns:1fr}
  .ibe-offer-row{grid-template-columns:1fr}
  .reserve-grid{grid-template-columns:1fr}
  .book-grid,.form-grid{grid-template-columns:1fr}
  .kln-sticky-cta{display:flex}
  body{padding-bottom:72px}
}

/* Mobile header factory controls */
.mobile-menu-btn{display:none;border:0;background:#FBFBF8;border-radius:22px;width:58px;height:58px;align-items:center;justify-content:center;box-shadow:0 14px 34px rgba(31,42,61,.10);padding:0;cursor:pointer}
.mobile-menu-btn span{display:block;width:24px;height:2px;background:#2F2F2F;margin:3px 0;border-radius:2px}

@media (max-width:767px){
  .site-header{position:sticky;top:0;background:rgba(251,251,248,.94)}
  .site-nav{height:124px;grid-template-columns:1fr auto 1fr;padding:4px 22px;max-width:none}
  .nav-left{display:none}
  .nav-right{justify-content:flex-end}
  .nav-right .nav-cta{display:none}
  .mobile-menu-btn{display:flex}
  .brand{grid-column:2;align-items:center;justify-self:center;justify-content:center;min-width:0;gap:0;height:100%}
  .brand img,.brand-logo{width:var(--site-logo-mobile-width,170px);height:var(--site-logo-mobile-height,88px);object-fit:contain}
  .brand-name{font-size:21px;white-space:nowrap}
  .kln-sticky-cta{display:flex}
}

/* v9 availability polish – mock/live contract-compatible offer cards */
.ibe-wrap{
  padding-top:84px;
}
.ibe-title{
  margin-bottom:42px;
}
.ibe-title h1{
  letter-spacing:-.025em;
}
.ibe-offers{
  max-width:960px;
  gap:16px;
}
.ibe-offer-card{
  border-color:rgba(171,132,72,.35);
  border-radius:14px;
  padding:16px;
  background:rgba(251,251,248,.98);
  box-shadow:none;
}
.ibe-offer-card:hover{
  border-color:rgba(171,132,72,.58);
}
.ibe-offer-row{
  grid-template-columns:260px 1fr;
  gap:18px;
  min-height:154px;
}
.ibe-offer-media{
  border-radius:10px;
  aspect-ratio:4/3;
}
.ibe-offer-copy{
  padding:2px 44px 2px 0;
}
.ibe-offer-copy h3{
  font-size:19px;
  line-height:1.25;
  margin-bottom:6px;
  color:#3C3C3C;
}
.ibe-offer-copy .sub{
  font-size:12px;
  margin-bottom:10px;
}
.ibe-offer-copy .desc{
  font-size:14px;
  line-height:1.48;
  margin-bottom:20px;
  color:#3F3F3F;
}
.rate-label{
  font-size:10px;
  letter-spacing:.20em;
  margin-bottom:6px;
}
.rate{
  font-size:14px;
  margin-bottom:5px;
  color:#24334A;
}
.rate-total{
  font-size:12px;
  color:var(--ibe-muted);
  margin-bottom:10px;
}
.ibe-select-offer{
  border-radius:6px;
  padding:12px 18px;
  font-size:11px;
  min-width:124px;
}
.offer-badge{
  right:15px;
  top:13px;
  padding:4px 8px;
  font-size:10px;
  letter-spacing:.04em;
}

@media (max-width:900px){
  .ibe-wrap{padding-top:58px;}
  .ibe-title{margin-bottom:30px;}
  .ibe-offers{gap:18px;}
  .ibe-offer-card{
    border-color:rgba(64,64,64,.18);
    border-radius:18px;
    padding:18px;
  }
  .ibe-offer-row{grid-template-columns:1fr;gap:18px;}
  .ibe-offer-media{aspect-ratio:1.45/1;border-radius:14px;}
  .ibe-offer-copy{padding-right:0;}
  .ibe-offer-copy h3{font-size:24px;}
  .ibe-offer-copy .sub{font-size:15px;}
  .ibe-offer-copy .desc{font-size:17px;line-height:1.55;}
  .offer-badge{display:none;}
}


/* v10 availability polish – compact card sizing + cleaner price narrative */
.ibe-wrap{
  padding-top:54px;
  padding-bottom:54px;
}
.ibe-title{
  margin-bottom:34px;
}
.ibe-offers{
  max-width:940px;
  gap:14px;
}
.ibe-offer-card{
  padding:14px;
  border-radius:15px;
}
.ibe-offer-row{
  grid-template-columns:250px 1fr;
  gap:16px;
  min-height:142px;
}
.ibe-offer-media{
  border-radius:10px;
}
.ibe-offer-copy{
  padding:1px 42px 1px 0;
}
.ibe-offer-copy h3{
  font-size:18.5px;
  line-height:1.2;
  margin-bottom:5px;
}
.ibe-offer-copy .sub{
  font-size:12px;
  line-height:1.35;
  margin-bottom:8px;
}
.ibe-offer-copy .desc{
  font-size:14px;
  line-height:1.45;
  margin-bottom:17px;
  max-width:62ch;
}
.rate-label{
  margin-bottom:5px;
}
.rate{
  margin-bottom:10px;
}
.rate-main{
  color:#24334A;
  font-size:14px;
  line-height:1.35;
}
.rate-detail{
  margin-top:2px;
  color:var(--ibe-muted);
  font-size:12px;
  line-height:1.35;
}
.ibe-select-offer{
  padding:11px 18px;
  border-radius:6px;
  min-width:124px;
}

@media (max-width:900px){
  .ibe-wrap{padding-top:46px;padding-bottom:46px;}
  .ibe-title{margin-bottom:28px;}
  .ibe-offers{gap:18px;}
  .ibe-offer-card{padding:18px;border-radius:18px;}
  .ibe-offer-row{grid-template-columns:1fr;gap:18px;min-height:0;}
  .ibe-offer-copy{padding-right:0;}
  .ibe-offer-copy h3{font-size:24px;}
  .ibe-offer-copy .sub{font-size:15px;}
  .ibe-offer-copy .desc{font-size:17px;line-height:1.55;}
}


/* v12 availability: no fallback badges; honest empty state for no live offers */
.offer-badge{display:none !important;}
.ibe-empty-state{
  max-width:940px;
  margin:0 auto;
  border:1px solid rgba(171,132,72,.35);
  border-radius:15px;
  background:rgba(251,251,248,.98);
  padding:32px 34px;
  color:#24334A;
}
.ibe-empty-state h2{
  font-size:22px;
  line-height:1.25;
  font-weight:400;
  margin:0 0 10px;
  color:#24334A;
}
.ibe-empty-state p{
  margin:0 0 22px;
  color:#7A7A7A;
  font-size:15px;
  line-height:1.55;
}

/* v13 reserve checkout polish */
.reserve-page{
  padding-top:34px;
}
.reserve-title{
  margin-bottom:18px;
}
.reserve-title h1{
  font-size:clamp(30px,3.15vw,38px);
  letter-spacing:-.02em;
  text-transform:none;
}
.reserve-title p{
  font-size:13px;
  color:var(--ibe-muted);
  margin-top:14px;
}
.reserve-grid-polished{
  max-width:900px;
  margin:0 auto;
  grid-template-columns:minmax(0,1.32fr) minmax(340px,.88fr);
  gap:18px;
  align-items:start;
}
.reserve-form-card,
.reserve-summary-card{
  padding:14px;
  border-radius:14px;
  background:rgba(251,251,248,.98);
  border-color:rgba(64,64,64,.16);
}
.reserve-card-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}
.reserve-card-head h2{
  font-size:15px;
  font-weight:400;
  margin:0;
  color:#404040;
}
.reserve-modify{
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--ibe-muted);
  border-bottom:1px solid rgba(64,64,64,.35);
  padding-bottom:3px;
}
.reserve-form-grid{
  gap:8px;
}
.reserve-form-card .ibe-field label{
  display:none;
}
.reserve-form-card .ibe-field input,
.reserve-form-card .ibe-field select,
.reserve-form-card .ibe-field textarea{
  border-radius:8px;
  border-color:rgba(64,64,64,.16);
  padding:9px 11px;
  font-size:13px;
  background:#fff;
}
.reserve-form-card .ibe-field textarea{
  min-height:58px;
}
.field-note{
  color:var(--ibe-muted);
  font-size:11px;
  line-height:1.45;
  margin:5px 0 0;
}
.phone-grid{
  display:grid;
  grid-template-columns:132px 1fr;
  gap:8px;
}
.whatsapp-line{
  margin-top:8px;
}
.inline-check{
  display:flex;
  align-items:flex-start;
  gap:9px;
  font-size:12px;
  line-height:1.45;
  color:#596172;
}
.inline-check input{
  margin-top:2px;
  flex:0 0 auto;
}
.legal-check{
  border:1px solid rgba(64,64,64,.12);
  border-radius:8px;
  padding:9px 10px;
  background:#fff;
}
.addon-card{
  border:1px solid rgba(64,64,64,.12);
  border-radius:10px;
  padding:11px;
  background:#fff;
  display:grid;
  gap:7px;
}
.addon-copy strong{
  display:block;
  font-weight:500;
  font-size:13px;
  color:#404040;
}
.addon-copy span,
.addon-copy small{
  display:block;
  color:var(--ibe-muted);
  font-size:11.5px;
  line-height:1.45;
  margin-top:3px;
}
.summary-offer-head{
  display:grid;
  grid-template-columns:74px 1fr;
  gap:12px;
  align-items:center;
  margin-bottom:16px;
}
.summary-offer-head img{
  width:74px;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:8px;
}
.summary-offer-head h2{
  font-size:15px;
  line-height:1.3;
  font-weight:400;
  margin:0 0 4px;
  color:#404040;
}
.summary-offer-head p{
  margin:0;
  font-size:11px;
  color:var(--ibe-muted);
  line-height:1.45;
}
.summary-group{
  padding:6px 0 9px;
  border-top:1px solid rgba(64,64,64,.10);
}
.summary-line{
  border:0;
  padding:5px 0;
  gap:14px;
  font-size:12px;
  color:var(--ibe-muted);
}
.summary-line strong{
  font-weight:500;
  color:#404040;
  text-align:right;
}
.summary-line.total{
  margin-top:3px;
  padding-top:10px;
  border-top:1px solid rgba(64,64,64,.10);
  color:#404040;
}
.summary-line.total strong{
  font-size:14px;
}
.conditions-box{
  border-top:1px solid rgba(64,64,64,.10);
  padding-top:12px;
  margin-top:2px;
}
.conditions-box h3{
  margin:0 0 8px;
  color:var(--ibe-muted);
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:400;
  line-height:1.4;
}
.conditions-line{
  display:flex;
  justify-content:space-between;
  gap:14px;
  padding:4px 0;
  font-size:11.5px;
  color:var(--ibe-muted);
}
.conditions-line strong{
  font-weight:500;
  color:#404040;
  text-align:right;
}
.reserve-pay-button{
  width:100%;
  margin-top:14px;
  border-radius:6px;
  padding:12px 18px;
}
.reserve-notice{
  max-width:760px;
  margin:0 auto;
}
@media (max-width:900px){
  .reserve-page{padding-top:40px;}
  .reserve-grid-polished{grid-template-columns:1fr;max-width:620px;}
  .phone-grid{grid-template-columns:1fr;}
  .summary-offer-head{grid-template-columns:88px 1fr;}
  .summary-offer-head img{width:88px;}
}

/* v14 reserve mock/testing + refined toggle controls */
.reserve-transfer-line{display:none;}
.reserve-form-card .inline-check input[type="checkbox"],
.reserve-summary-card input[type="checkbox"]{
  accent-color:#2F2F2F;
}
.whatsapp-line,
.addon-card .inline-check{
  align-items:center;
  justify-content:space-between;
  gap:14px;
}
.whatsapp-line input[type="checkbox"],
.addon-card .inline-check input[type="checkbox"]{
  appearance:none;
  -webkit-appearance:none;
  width:38px;
  height:22px;
  border-radius:999px;
  border:1px solid rgba(64,64,64,.22);
  background:#e8e8e5;
  position:relative;
  cursor:pointer;
  flex:0 0 auto;
  transition:background-color .18s ease,border-color .18s ease;
}
.whatsapp-line input[type="checkbox"]::after,
.addon-card .inline-check input[type="checkbox"]::after{
  content:"";
  position:absolute;
  top:2px;
  left:2px;
  width:16px;
  height:16px;
  border-radius:50%;
  background:#fff;
  box-shadow:0 1px 3px rgba(0,0,0,.18);
  transition:transform .18s ease;
}
.whatsapp-line input[type="checkbox"]:checked,
.addon-card .inline-check input[type="checkbox"]:checked{
  background:#2F2F2F;
  border-color:#2F2F2F;
}
.whatsapp-line input[type="checkbox"]:checked::after,
.addon-card .inline-check input[type="checkbox"]:checked::after{
  transform:translateX(16px);
}
.addon-card .inline-check{
  border:1px solid rgba(64,64,64,.12);
  border-radius:8px;
  padding:9px 10px;
  background:#FBFBF8;
}


/* v17 reserve acceptance + payment CTA refinement */
.reserve-acceptance-line{
  display:flex;
  align-items:flex-start;
  gap:9px;
  margin-top:12px;
  padding:10px 11px;
  border:1px solid rgba(64,64,64,.12);
  border-radius:8px;
  background:#fff;
  color:#596172;
  font-size:11.5px;
  line-height:1.45;
}
.reserve-acceptance-line input{
  margin-top:2px;
  flex:0 0 auto;
  accent-color:#2F2F2F;
}
.reserve-acceptance-line a{
  text-decoration:underline;
  text-underline-offset:2px;
}
.reserve-inline-error{
  display:none;
  margin:8px 0 0;
  padding:8px 10px;
  border:1px solid rgba(176,0,32,.20);
  border-radius:8px;
  background:rgba(176,0,32,.035);
  color:#8A1F2D;
  font-size:11.5px;
  line-height:1.45;
}
.reserve-pay-button,
.reserve-pay-button:link,
.reserve-pay-button:visited{
  width:100%;
  margin-top:14px;
  border-radius:6px;
  padding:12px 18px;
  border:1px solid #2F2F2F !important;
  background:#2F2F2F !important;
  color:#FBFBF8 !important;
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:12px;
  transition:background-color .2s ease,color .2s ease,border-color .2s ease,transform .2s ease,opacity .2s ease;
}
.reserve-pay-button:not(:disabled):hover,
.reserve-pay-button:not(:disabled):focus-visible{
  background:#3B3B3B !important;
  color:#FBFBF8 !important;
  border-color:#3B3B3B !important;
  transform:translateY(-1px);
  outline:none;
}
.reserve-pay-button:not(:disabled):active{
  transform:translateY(0);
}
.reserve-pay-button:disabled,
.reserve-pay-button[aria-disabled="true"]{
  background:transparent !important;
  color:rgba(64,64,64,.38) !important;
  border-color:rgba(64,64,64,.18) !important;
  cursor:not-allowed !important;
  opacity:1 !important;
  transform:none !important;
}


/* v18 reserve validation refinement */
.ibe-field input.is-invalid{
  border-color:rgba(138,31,45,.55) !important;
  box-shadow:0 0 0 2px rgba(138,31,45,.08) !important;
}
.field-error{
  display:none;
  color:#8A1F2D !important;
  margin-top:5px !important;
}

/* v19 reserve billing readability + stricter email validation styling */
.reserve-form-card .ibe-field input.is-invalid{
  border-color:rgba(145,34,42,.55) !important;
  box-shadow:0 0 0 2px rgba(145,34,42,.08) !important;
}
.field-error{
  color:#8E252C !important;
  margin-top:5px !important;
}
.summary-pricing-v19{
  padding-top:10px;
}
.summary-pricing-v19 .summary-line{
  display:none;
}
.summary-price-row{
  display:grid;
  grid-template-columns:minmax(0,1.1fr) minmax(92px,.85fr) minmax(78px,.55fr);
  gap:12px;
  align-items:baseline;
  padding:5px 0;
  font-size:12px;
  color:var(--ibe-muted);
  column-gap:12px;
}
.summary-price-row span{
  min-width:0;
}
.summary-price-row em{
  font-style:normal;
  color:rgba(64,64,64,.58);
  text-align:right;
  font-size:11px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.summary-price-row strong{
  font-weight:500;
  color:#404040;
  text-align:right;
  white-space:nowrap;
}
.summary-price-row.is-subtotal{
  padding-top:7px;
  margin-top:2px;
  border-top:1px solid rgba(64,64,64,.08);
}
.summary-price-row.is-subtotal span,
.summary-price-row.total span{
  color:#404040;
}
.summary-price-row.total{
  margin-top:5px;
  padding-top:11px;
  border-top:1px solid rgba(64,64,64,.12);
}
.summary-price-row.total strong{
  font-size:14px;
}
.reserve-base-service-line + .reserve-base-service-line{
  margin-top:1px;
}
@media (max-width:720px){
  .summary-price-row{
    grid-template-columns:minmax(0,1fr) minmax(70px,.65fr);
  }
  .summary-price-row em{
    grid-column:1 / 2;
    text-align:left;
    font-size:10.5px;
    margin-top:-2px;
  }
  .summary-price-row strong{
    grid-column:2 / 3;
    grid-row:1 / span 2;
    align-self:center;
  }
}


/* v20 reserve fine tuning: cleaner billing grid + robust pay-ready state */
.reserve-summary-card .summary-price-row span{
  line-height:1.15;
}
.reserve-summary-card .summary-price-row strong{
  font-variant-numeric:tabular-nums;
}
.reserve-summary-card .reserve-transfer-line span,
.reserve-summary-card .reserve-base-service-line span{
  max-width:12.5em;
}
.reserve-pay-button.is-ready:not(:disabled),
.reserve-pay-button:not(:disabled){
  background:#2F2F2F !important;
  color:#FBFBF8 !important;
  border-color:#2F2F2F !important;
  cursor:pointer !important;
}
.reserve-pay-button.is-ready:not(:disabled):hover,
.reserve-pay-button:not(:disabled):hover{
  background:#3B3B3B !important;
  color:#FBFBF8 !important;
  border-color:#3B3B3B !important;
}
.reserve-pay-button:disabled,
.reserve-pay-button[aria-disabled="true"]{
  background:transparent !important;
  color:rgba(64,64,64,.38) !important;
  border-color:rgba(64,64,64,.18) !important;
  cursor:not-allowed !important;
}


/* v23 reserve billing grid: preserve v21 layout, but give calculation column enough room */
.reserve-summary-card .summary-price-row{
  grid-template-columns:minmax(0,.88fr) minmax(142px,142px) minmax(72px,72px) !important;
  column-gap:10px !important;
}
.reserve-summary-card .summary-price-row.is-line em{
  color:rgba(64,64,64,.60) !important;
  text-align:right !important;
  font-size:10.5px !important;
  white-space:nowrap !important;
  overflow:visible !important;
  text-overflow:clip !important;
}
.reserve-summary-card .summary-price-row.is-line strong{
  display:block !important;
  color:transparent !important;
  pointer-events:none !important;
  user-select:none !important;
}
.reserve-summary-card .summary-price-row.is-subtotal em,
.reserve-summary-card .summary-price-row.total em{
  color:transparent !important;
  pointer-events:none !important;
  user-select:none !important;
}
.reserve-summary-card .summary-price-row.is-subtotal strong,
.reserve-summary-card .summary-price-row.total strong{
  text-align:right !important;
}
.reserve-summary-card .summary-price-row.total strong{
  font-size:15px !important;
  font-weight:500 !important;
}
.reserve-summary-card .summary-price-row.is-rate{
  padding-bottom:6px !important;
}
.reserve-summary-card .reserve-transfer-line span,
.reserve-summary-card .reserve-base-service-line span{
  max-width:none !important;
}
/* WhatsApp opt-in: visible under phone, but only enabled once a plausible phone number exists */
.whatsapp-line.is-disabled{
  opacity:.55;
  cursor:not-allowed;
}
.whatsapp-line.is-disabled input[type="checkbox"]{
  cursor:not-allowed !important;
}
@media (max-width:720px){
  .reserve-summary-card .summary-price-row{
    grid-template-columns:minmax(0,.86fr) minmax(128px,128px) minmax(68px,68px) !important;
    gap:8px !important;
  }
  .reserve-summary-card .summary-price-row em,
  .reserve-summary-card .summary-price-row strong{
    grid-column:auto !important;
    grid-row:auto !important;
    align-self:baseline !important;
  }
  .reserve-summary-card .summary-price-row.is-line em{
    font-size:10px !important;
    text-align:right !important;
    margin-top:0 !important;
  }
}


/* v25 final reserve WhatsApp opt-in: explicit toggle under phone, enabled only with plausible phone */
.whatsapp-optin-line{
  margin-top:8px;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:14px !important;
  font-size:12px;
  line-height:1.45;
  color:#596172;
  cursor:pointer;
}
.whatsapp-optin-line span{
  display:block;
  min-width:0;
  flex:1 1 auto;
}
.whatsapp-optin-line input[type="checkbox"]{
  display:block !important;
  appearance:none !important;
  -webkit-appearance:none !important;
  width:38px !important;
  height:22px !important;
  min-width:38px !important;
  border-radius:999px !important;
  border:1px solid rgba(64,64,64,.22) !important;
  background:#e8e8e5 !important;
  position:relative !important;
  cursor:pointer;
  flex:0 0 38px !important;
  margin:0 !important;
  opacity:1 !important;
  transition:background-color .18s ease,border-color .18s ease;
}
.whatsapp-optin-line input[type="checkbox"]::after{
  content:"";
  position:absolute;
  top:2px;
  left:2px;
  width:16px;
  height:16px;
  border-radius:50%;
  background:#fff;
  box-shadow:0 1px 3px rgba(0,0,0,.18);
  transition:transform .18s ease;
}
.whatsapp-optin-line input[type="checkbox"]:checked{
  background:#2F2F2F !important;
  border-color:#2F2F2F !important;
}
.whatsapp-optin-line input[type="checkbox"]:checked::after{
  transform:translateX(16px);
}
.whatsapp-optin-line.is-disabled{
  opacity:.55;
  cursor:not-allowed;
}
.whatsapp-optin-line.is-disabled input[type="checkbox"]{
  cursor:not-allowed !important;
}


/* v26 reserve acceptance guidance: subtle inline prompt once all required fields are complete */
.reserve-inline-error.is-guidance{
  border-color:rgba(64,64,64,.16) !important;
  background:rgba(243,238,231,.55) !important;
  color:#596172 !important;
}


/* v27 final reserve polish: clear payment microcopy + quiet Stripe trust layer */
.reserve-pay-button.is-ready:not(:disabled),
.reserve-pay-button:not(:disabled){
  letter-spacing:.13em !important;
}
.reserve-trust-layer{
  margin-top:9px;
  text-align:center;
  color:#8A8A86;
  font-size:11px;
  line-height:1.35;
  letter-spacing:.015em;
}
.reserve-trust-layer strong{
  color:#595955;
  font-weight:500;
}
.reserve-pay-button:disabled + .reserve-trust-layer{
  opacity:.68;
}

/* v28 reserve final polish: single Apple-friendly phone field + stronger acceptance guidance */
.phone-field input[name="phone_full"]{
  width:100%;
}
.phone-field input[name="phone_country_code"],
.phone-field input[name="phone_national"]{
  display:none !important;
}
.reserve-inline-error.is-guidance{
  border:1px solid rgba(47,47,47,.26) !important;
  border-left:3px solid #2F2F2F !important;
  background:#FBFBF8 !important;
  color:#404040 !important;
  font-size:12px !important;
  line-height:1.45 !important;
  padding:10px 12px !important;
  box-shadow:0 2px 10px rgba(0,0,0,.035) !important;
}


/* v29 reserve phone field: visually one international field, semantically split for Apple/Safari autofill */
.phone-field .ibe-phone-combo{
  width:100%;
  display:grid;
  grid-template-columns:auto 54px auto 1fr;
  align-items:center;
  gap:0;
  border:1px solid rgba(64,64,64,.16);
  border-radius:8px;
  background:#fff;
  overflow:hidden;
  min-height:36px;
}
.phone-field .phone-plus{
  color:#9A9A94;
  padding-left:11px;
  font-size:13px;
  line-height:1;
  user-select:none;
}
.phone-field .phone-divider{
  width:1px;
  height:18px;
  background:rgba(64,64,64,.12);
  margin:0 6px;
}
.reserve-form-card .phone-field .ibe-phone-combo input,
.phone-field .ibe-phone-combo input{
  border:0 !important;
  border-radius:0 !important;
  background:transparent !important;
  padding:9px 6px !important;
  box-shadow:none !important;
  min-width:0;
  width:100%;
}
.phone-field .ibe-phone-combo input[name="phone_country_code"]{
  text-align:left;
  padding-left:4px !important;
}
.phone-field .ibe-phone-combo input[name="phone_national"]{
  padding-left:6px !important;
}
.phone-field .ibe-phone-combo:focus-within{
  outline:2px solid rgba(80,130,255,.45);
  outline-offset:1px;
  border-color:rgba(64,64,64,.22);
}
.phone-field input[name="phone_full"]{
  display:none !important;
}
.phone-field input[name="phone_country_code"],
.phone-field input[name="phone_national"]{
  display:block !important;
}

/* v30 reserve phone field: one native tel field for Safari/Apple autofill; strict +IDD validation in JS */
.reserve-form-card .phone-field input[name="phone_full"],
.phone-field input[name="phone_full"]{
  display:block !important;
  width:100% !important;
}
.phone-field input[name="phone_country_code"],
.phone-field input[name="phone_national"],
.phone-field .ibe-phone-combo,
.phone-field .phone-plus,
.phone-field .phone-divider{
  display:none !important;
}

/* v31 reserve phone: protected + country code field + local phone, stitched into hidden phone_full */
.phone-field.phone-field-v31 input[name="phone_full"]{
  display:none !important;
}
.phone-field.phone-field-v31 .phone-grid-v31{
  display:grid !important;
  grid-template-columns:118px 1fr;
  gap:8px;
  width:100%;
}
.phone-field.phone-field-v31 input[name="phone_country_code"],
.phone-field.phone-field-v31 input[name="phone_national"]{
  display:block !important;
  width:100% !important;
}
.phone-field.phone-field-v31 input[name="phone_country_code"]{
  text-align:left;
  font-variant-numeric:tabular-nums;
}
.phone-field.phone-field-v31 .whatsapp-optin-line{
  margin-top:8px;
}
@media (max-width:640px){
  .phone-field.phone-field-v31 .phone-grid-v31{
    grid-template-columns:96px 1fr;
  }
}

/* v34 confirmation polish – EUR-only, 100% zoom density tuned */
.confirm-page{max-width:1120px;padding-top:58px;}
.confirm-title{margin-bottom:26px;}
.confirm-title h1{font-size:clamp(32px,3.4vw,43px);letter-spacing:-.025em;}
.confirm-title p{font-size:13px;}
.confirm-card{max-width:720px;margin:0 auto;padding:16px 18px;border-radius:13px;background:#FBFBF8;}
.confirm-head{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;padding-bottom:12px;border-bottom:1px solid rgba(64,64,64,.12);}
.confirm-head h2{font-size:17px;font-weight:500;color:#333;margin:0 0 6px;}
.confirm-head p{margin:0;color:#6f6f6f;font-size:13px;line-height:1.4;}
.confirm-ref{min-width:210px;max-width:320px;text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-size:10.5px;color:#9a9a9a;}
.confirm-ref code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;color:#777;font-size:10.5px;word-break:break-all;}
.confirm-res-label{margin-top:6px;opacity:.7;}
.confirm-sections{padding-top:12px;}
.confirm-block{margin-top:3px;}
.confirm-status-row,.confirm-transfer-line{display:flex;align-items:center;gap:9px;}
.confirm-status-row strong,.confirm-transfer-line strong{font-size:14px;font-weight:600;color:#333;line-height:1.4;}
.confirm-dot{width:8px;height:8px;border-radius:99px;background:#c9c9c9;flex:0 0 8px;display:inline-block;}
.confirm-dot.is-ok{background:#2e7d32;}
.confirm-dot.is-fail{background:#b00020;}
.confirm-dot.is-wait,.confirm-dot.is-muted{background:#c9c9c9;}
.confirm-lines{margin-left:17px;margin-top:7px;color:#6f6f6f;font-size:13px;line-height:1.48;}
.confirm-divider{margin:10px 0;border-top:1px solid rgba(64,64,64,.12);}
.confirm-transfer-line + .confirm-transfer-line{margin-top:8px;}
.confirm-transfer-line a{color:#333;text-decoration:underline;text-underline-offset:2px;}
.confirm-transfer-hint{margin:8px 0 0 17px;color:#6f6f6f;font-size:11.5px;line-height:1.42;}
.confirm-small{font-size:11.5px;color:#777;}
.confirm-reference-value{display:block;margin-top:2px;color:#777;font-size:10.5px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;word-break:break-all;overflow-wrap:anywhere;}
.confirm-actions{margin-top:13px;display:flex;gap:9px;flex-wrap:wrap;}
.confirm-action{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;border-radius:6px;padding:10px 14px;color:#333;background:#fff;border:1px solid rgba(64,64,64,.22);font-size:12px;transition:background-color .18s ease,color .18s ease,border-color .18s ease;}
.confirm-action.is-primary,.confirm-action:hover{color:#FBFBF8;background:#2F2F2F;border-color:#2F2F2F;}
.confirm-debug{margin-top:12px;font-size:11.5px;color:#888;white-space:pre-wrap;word-break:break-word;}
.confirm-card.is-success{border-color:rgba(46,125,50,.24);}
.confirm-card.is-failed{border-color:rgba(176,0,32,.24);}

@media (max-width:760px){
  .confirm-page{padding-top:48px;}
  .confirm-card{padding:16px;border-radius:16px;}
  .confirm-head{display:block;}
  .confirm-ref{margin-top:14px;text-align:left;align-items:flex-start;min-width:0;max-width:none;}
  .confirm-actions{display:grid;grid-template-columns:1fr;}
  .confirm-action{width:100%;}
}

/* v35 confirmation 100%-zoom scale tuning
   Goal: Safari/Chrome at default 100% render visually close to the previous Chrome 80% target. */
.confirm-page{
  --confirm-page-scale: .82;
  zoom: var(--confirm-page-scale);
  padding-top: 50px;
  padding-bottom: 42px;
}
.confirm-title{
  margin-bottom: 22px;
}
.confirm-card{
  max-width: 720px;
}

/* Fallback for engines where zoom is disabled: keep centred and avoid horizontal drift. */
@supports not (zoom: 1){
  .confirm-page{
    transform: scale(var(--confirm-page-scale));
    transform-origin: top center;
    width: calc(100% / var(--confirm-page-scale));
    max-width: calc(1120px / var(--confirm-page-scale));
    margin-left: auto;
    margin-right: auto;
  }
}

@media (max-width:900px){
  .confirm-page{
    zoom: 1;
    padding-top: 48px;
  }
}

/* v37 static page polish – same visual language as IBE pages */
.static-page{
  background:#FBFBF8;
  min-height:calc(100svh - 92px);
  padding:70px 24px 90px;
}
.static-container{
  width:min(100%,960px);
  margin:0 auto;
}
.static-hero{
  width:min(100%,900px);
  margin:0 auto 42px;
  text-align:center;
}
.static-hero.compact{margin-bottom:34px;}
.static-eyebrow{
  margin:0 0 14px;
  color:var(--ibe-muted);
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
}
.static-hero h1{
  margin:0 auto 18px;
  color:var(--ibe-text);
  font-size:clamp(36px,4.7vw,58px);
  font-weight:400;
  line-height:1.08;
  letter-spacing:-.035em;
  max-width:820px;
}
.static-lead{
  margin:0 auto;
  max-width:720px;
  color:#6F6F6F;
  font-size:16px;
  line-height:1.65;
}
.static-actions{
  display:flex;
  justify-content:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:26px;
}
.static-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:154px;
  padding:13px 20px;
  border-radius:6px;
  border:1px solid var(--ibe-line-strong);
  letter-spacing:.16em;
  text-transform:uppercase;
  font-size:11px;
  transition:background-color .18s ease,color .18s ease,border-color .18s ease,transform .18s ease;
}
.static-btn.primary{
  background:#2F2F2F;
  color:#FBFBF8;
  border-color:#2F2F2F;
}
.static-btn.secondary{
  background:transparent;
  color:#404040;
}
.static-btn:hover,
.static-btn:focus-visible{
  background:#2F2F2F;
  border-color:#2F2F2F;
  color:#F3EEE7;
  outline:none;
}
.static-btn:active{transform:translateY(1px);}
.static-card{
  border:1px solid rgba(64,64,64,.18);
  border-radius:16px;
  background:#FBFBF8;
  overflow:hidden;
}
.static-grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.compact-card{
  padding:20px;
  min-height:154px;
}
.compact-card h2,
.room-line-copy h2,
.facility-card h2{
  margin:0 0 8px;
  color:#3C3C3C;
  font-weight:400;
  line-height:1.22;
}
.compact-card h2{font-size:20px;}
.compact-card p,
.room-line-copy p,
.facility-card p{
  margin:0;
  color:#6F6F6F;
  line-height:1.6;
  font-size:14px;
}
.room-stack{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.room-line-card{
  display:grid;
  grid-template-columns:300px 1fr;
  gap:20px;
  padding:16px;
  align-items:center;
  border-color:rgba(171,132,72,.35);
}
.room-line-card:hover{border-color:rgba(171,132,72,.58);}
.room-line-media{
  border-radius:12px;
  overflow:hidden;
  aspect-ratio:4/3;
  background:#eee;
}
.room-line-media img{
  width:100%;
  height:100%;
  object-fit:cover;
}
.room-line-copy{padding:2px 10px 2px 0;}
.room-line-copy h2{font-size:24px;}
.room-meta{
  color:#7A7A7A !important;
  font-size:13px !important;
  margin-bottom:12px !important;
}
.text-link{
  display:inline-block;
  margin-top:18px;
  color:#404040;
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  border-bottom:1px solid rgba(64,64,64,.45);
  padding-bottom:4px;
}
.facility-list{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.facility-card{
  padding:20px;
  display:grid;
  grid-template-columns:40px 1fr;
  gap:12px;
  align-items:start;
}
.facility-kicker{
  color:#A47A45;
  font-size:12px;
  letter-spacing:.18em;
  padding-top:4px;
}
.facility-card h2{font-size:21px;}

@media (max-width:900px){
  .static-page{padding:54px 18px 92px;}
  .static-grid-3,.facility-list{grid-template-columns:1fr;}
  .room-line-card{grid-template-columns:1fr;padding:18px;border-color:rgba(64,64,64,.18);}
  .room-line-media{aspect-ratio:1.45/1;border-radius:14px;}
  .room-line-copy{padding:0;}
  .room-line-copy h2{font-size:24px;}
}
