:root {
  --bg: #f5f2ea;
  --surface: #ffffff;
  --surface-alt: #f7f4ee;
  --text: #223226;
  --muted: #5b6c60;
  --primary: #214f33;
  --primary-2: #335f41;
  --gold: #b39a63;
  --line: #d8d9cf;
  --shadow: 0 20px 40px rgba(18,35,24,.08);
  --radius: 24px;
  --container: 1180px;
}
*{box-sizing:border-box}
body{margin:0;font-family:Arial,Helvetica,sans-serif;background:linear-gradient(180deg,#f7f4ee 0%,#f1efe8 100%);color:var(--text)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{width:min(calc(100% - 32px),var(--container));margin:0 auto}
.topbar{position:sticky;top:0;z-index:20;background:linear-gradient(180deg,#123522 0%,#163f29 100%);box-shadow:0 12px 24px rgba(0,0,0,.12)}
.nav-row{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:18px 0}
.brand{display:flex;align-items:center;gap:14px;color:#fff;font-weight:800;letter-spacing:.08em}
.brand img{width:56px;height:56px;border-radius:16px;border:1px solid rgba(255,255,255,.2);object-fit:cover;background:#fff;padding:4px}
.nav-right{display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:flex-end}
.nav-links,.nav-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.nav-links a,.mini-btn{color:#fff;padding:10px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);font-weight:700}
.nav-links a.active,.nav-links a:hover,.mini-btn:hover{background:rgba(255,255,255,.14)}
.hero{padding:34px 0 20px}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:stretch}
.hero-copy,.hero-media,.card,.feature-card,.notice,.faq-item,.contact-card,.place-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.hero-copy{padding:34px}
.hero-copy h1{margin:0 0 14px;font-size:clamp(34px,4vw,56px);line-height:1.05}
.lead{font-size:18px;color:var(--muted);line-height:1.65;margin:0;white-space:pre-line}
.eyebrow{display:inline-block;padding:8px 12px;border-radius:999px;background:#edf5ef;color:var(--primary);font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;margin-bottom:18px}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:13px 18px;border-radius:999px;font-weight:800}
.btn-primary{background:var(--primary);color:#fff}
.btn-secondary{background:#fff;border:1px solid var(--line);color:var(--primary)}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:24px}
.kpi{padding:14px;border-radius:18px;background:var(--surface-alt);border:1px solid #e8e4dc}
.kpi strong{display:block;font-size:20px;color:var(--primary)}
.kpi span{display:block;color:var(--muted);margin-top:4px}
.hero-media{position:relative;overflow:hidden;min-height:420px}
.hero-photo{width:100%;height:100%;object-fit:cover}
.hero-badge{position:absolute;left:18px;right:18px;bottom:18px;padding:16px 18px;border-radius:20px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.8)}
.hero-badge strong{display:block;color:var(--primary-2)}
.hero-badge .small{font-size:14px;color:var(--muted);margin-top:4px}
.section{padding:14px 0 10px}
.section-head{display:flex;justify-content:space-between;align-items:end;margin-bottom:16px}
.section-head h2{margin:6px 0 0;font-size:32px}
.grid-3,.feature-grid,.contact-grid,.places-grid{display:grid;gap:16px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.feature-grid{grid-template-columns:repeat(4,1fr)}
.contact-grid{grid-template-columns:repeat(3,1fr)}
.places-grid{grid-template-columns:repeat(3,1fr)}
.card,.feature-card,.contact-card,.place-card,.notice,.faq-item{padding:24px}
.label{font-size:12px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.card p,.feature-card p,.contact-card p,.place-card p,.notice p,.faq-item p{margin:0;color:var(--muted);line-height:1.65}
.feature-card h3,.contact-card h3,.place-card h3,.faq-item h3{margin:0 0 10px;font-size:20px}
.carousel-shell{padding:0;background:transparent;border-radius:0;border:none;box-shadow:none}
.carousel-view{position:relative;overflow:hidden;border-radius:22px}
.carousel-view img{width:100%;height:520px;object-fit:contain;background:transparent}
.carousel-dots{display:flex;justify-content:center;gap:8px;margin-top:14px}
.carousel-dot{width:10px;height:10px;border-radius:999px;border:none;background:#c9cdc6;cursor:pointer}
.carousel-dot.active{background:var(--primary)}
.faq-list{display:grid;gap:16px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.contact-strip{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}
.notice-bottom{margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.tag{padding:9px 12px;background:#edf5ef;border-radius:999px;color:var(--primary);font-weight:700;font-size:14px}
.qr-wrap{display:grid;grid-template-columns:180px 1fr;gap:16px;align-items:center}
.qr-wrap img{width:180px;height:180px;object-fit:cover;border-radius:18px;border:1px solid var(--line)}
.map-frame{width:100%;height:320px;border:0;border-radius:20px;pointer-events:none}
.footer{margin-top:30px;padding:30px 0;background:linear-gradient(180deg,#123522 0%,#163f29 100%);color:#fff}
.footer-box{display:flex;justify-content:space-between;gap:20px;align-items:center}
.footer-actions{display:flex;gap:12px;flex-wrap:wrap}
.footer p{color:rgba(255,255,255,.85);margin:8px 0 0}
ul{margin:0;padding-left:18px}
li{margin:6px 0;color:var(--muted)}
.cta-row{margin-top:18px}
@media (max-width: 1080px){.hero-grid,.grid-3,.feature-grid,.contact-grid,.places-grid,.grid-2{grid-template-columns:1fr 1fr}.feature-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width: 820px){.nav-row{align-items:flex-start}.nav-right{justify-content:flex-start}.hero-grid,.grid-3,.feature-grid,.contact-grid,.places-grid,.grid-2,.qr-wrap,.kpis{grid-template-columns:1fr}.footer-box{flex-direction:column;align-items:flex-start}.carousel-view img{height:360px}}
@media (max-width: 580px){.hero-copy,.hero-media,.card,.feature-card,.contact-card,.place-card,.notice,.faq-item{padding:20px}.nav-links,.nav-actions{width:100%}.nav-links a,.mini-btn,.btn{width:100%;justify-content:center}}


.hero-small{padding-top:24px}
.room-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}
.room-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column}
.room-card-image img{width:100%;height:220px;object-fit:cover}
.room-card-body{padding:18px;display:flex;flex-direction:column;gap:12px}
.room-card-top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.room-card-body p{margin:0;color:var(--muted);line-height:1.55}
.room-card-meta{display:flex;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:14px}
.room-card-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:auto}
.room-gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px}
.room-gallery-item{margin:0;background:var(--surface);border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow)}
.room-gallery-item img{width:100%;height:320px;object-fit:cover}
@media (max-width: 980px){
  .room-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .room-gallery{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .room-grid{grid-template-columns:1fr}
}

.home-contact-extra{display:grid;grid-template-columns:1.1fr .9fr;gap:16px;margin-top:18px}
.home-map-card,.home-qr-card{padding:18px;border:1px solid var(--line);border-radius:20px;background:#fbfcfa}
.home-map-card h3,.home-qr-card h3{margin:0 0 12px;font-size:20px}
.home-qr-card p{margin:0 0 14px;color:var(--muted);line-height:1.6}
.home-qr-card img{width:260px;max-width:100%;height:auto;border-radius:18px;border:1px solid var(--line);background:#fff}
@media (max-width: 820px){.home-contact-extra{grid-template-columns:1fr}}

.lang-switcher{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.lang-btn{appearance:none;display:inline-flex;align-items:center;justify-content:center;text-decoration:none;color:#111;border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:10px 12px;min-width:48px;font-weight:800;cursor:pointer;box-shadow:0 4px 10px rgba(15,23,42,.12)}
.lang-btn[data-lang="it"]{background:linear-gradient(90deg,#009246 0 33%,#fff 33% 66%,#ce2b37 66% 100%)}
.lang-btn[data-lang="en"]{background:url("/images/lang/uk-flag-v3.png") center/cover no-repeat;color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.72)}
.lang-btn[data-lang="ru"]{background:linear-gradient(180deg,#fff 0 33%,#1c57a7 33% 66%,#cf323e 66% 100%)}
.lang-btn[data-lang="uk"]{background:linear-gradient(180deg,#1b75d0 0 50%,#ffd700 50% 100%)}
.lang-btn[data-lang="fr"]{background:linear-gradient(90deg,#0055a4 0 33%,#fff 33% 66%,#ef4135 66% 100%);color:#111}
.lang-btn[data-lang="de"]{background:linear-gradient(180deg,#000 0 33%,#dd0000 33% 66%,#ffce00 66% 100%);color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.72)}
.lang-btn.active{transform:translateY(-1px);box-shadow:0 0 0 2px rgba(255,255,255,.4),0 8px 18px rgba(15,23,42,.18)}
@media(max-width:820px){.topbar .lang-switcher{width:144px;display:grid;grid-template-columns:repeat(3,42px);gap:6px;justify-content:center;align-items:center}.topbar .lang-btn{width:42px;min-width:42px;padding:6px 0;font-size:11px;line-height:1.1}.topbar .nav-row{gap:10px}.topbar .nav-right{flex:1;min-width:0}.topbar .brand{gap:10px}.topbar .brand img{width:48px;height:48px}.topbar .brand span{font-size:13px;line-height:1.15}}

.feature-card-wide{grid-column:span 2}
@media (max-width: 1080px){.feature-card-wide{grid-column:span 2}}
@media (max-width: 820px){.feature-card-wide{grid-column:span 1}}


.booking-offer-section{padding-top:54px;padding-bottom:64px}
.booking-offer-card{max-width:820px;margin:0 auto;background:rgba(255,255,255,.94);border:1px solid rgba(54,82,130,.16);box-shadow:0 24px 70px rgba(28,45,90,.12);border-radius:28px;padding:32px}
.booking-offer-brand{display:flex;align-items:center;gap:18px;margin-bottom:20px}
.booking-offer-brand img{width:68px;height:68px;border-radius:18px;object-fit:cover;background:#fff;padding:5px;box-shadow:0 12px 28px rgba(21,40,84,.12)}
.booking-offer-brand h1{margin:4px 0 0;font-size:clamp(28px,4vw,44px);line-height:1.08;color:var(--text)}
.booking-offer-lead{font-size:20px;line-height:1.55;color:var(--text);margin:18px 0 8px;font-weight:700}
.booking-offer-text{font-size:17px;line-height:1.7;color:var(--muted);margin:0 0 18px;white-space:pre-line}
.booking-offer-discount-note{border:1px solid rgba(41,86,58,.18);background:linear-gradient(135deg,#f1f8ef 0%,#fffdf2 100%);border-radius:20px;padding:18px 20px;margin:0 0 24px;box-shadow:0 12px 28px rgba(41,86,58,.08)}
.booking-offer-discount-note strong{display:block;color:#1f472d;font-size:18px;margin-bottom:8px}
.booking-offer-discount-note p{margin:0;color:#405143;font-size:16px;line-height:1.65}
.booking-offer-steps{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin:22px 0 26px}
.booking-offer-steps div{border:1px solid rgba(54,82,130,.14);background:#f7f9ff;border-radius:18px;padding:16px;display:flex;gap:12px;align-items:center;color:var(--text);font-weight:700}
.booking-offer-steps strong{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:999px;background:var(--accent);color:#fff;flex:0 0 auto}
.booking-offer-actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.booking-offer-alert{border-radius:16px;background:#fff1f1;color:#8c1d1d;border:1px solid #f1c6c6;padding:13px 15px;margin:12px 0 18px;font-weight:700}
@media (max-width:720px){.booking-offer-card{padding:22px;border-radius:22px}.booking-offer-brand{align-items:flex-start}.booking-offer-brand img{width:56px;height:56px}.booking-offer-steps{grid-template-columns:1fr}.booking-offer-actions .btn{width:100%;justify-content:center}.booking-offer-lead{font-size:18px}.booking-offer-text{font-size:15px}.booking-offer-discount-note{padding:16px}.booking-offer-discount-note strong{font-size:17px}.booking-offer-discount-note p{font-size:14px}}

/* H49.7: mobile polish for public home page only */
@media (max-width: 580px){
  body[data-i18n-page="home"]{
    overflow-x:hidden;
  }
  body[data-i18n-page="home"] .topbar{
    position:static;
  }
  body[data-i18n-page="home"] .container{
    width:calc(100% - 20px);
    max-width:100%;
  }
  body[data-i18n-page="home"] .nav-row{
    padding:12px 0;
  }
  body[data-i18n-page="home"] .hero{
    padding:12px 0 8px;
  }
  body[data-i18n-page="home"] .section{
    padding:8px 0;
  }
  body[data-i18n-page="home"] .hero-grid,
  body[data-i18n-page="home"] .grid-2,
  body[data-i18n-page="home"] .grid-3,
  body[data-i18n-page="home"] .feature-grid,
  body[data-i18n-page="home"] .contact-grid,
  body[data-i18n-page="home"] .places-grid,
  body[data-i18n-page="home"] .kpis{
    grid-template-columns:minmax(0,1fr);
    gap:10px;
  }
  body[data-i18n-page="home"] .hero-copy,
  body[data-i18n-page="home"] .hero-media,
  body[data-i18n-page="home"] .card,
  body[data-i18n-page="home"] .feature-card,
  body[data-i18n-page="home"] .notice,
  body[data-i18n-page="home"] .faq-item,
  body[data-i18n-page="home"] .contact-card,
  body[data-i18n-page="home"] .place-card{
    width:100%;
    max-width:100%;
    min-width:0;
    padding:14px;
    border-radius:18px;
    overflow:hidden;
  }
  body[data-i18n-page="home"] .hero-copy h1{
    font-size:28px;
    line-height:1.12;
  }
  body[data-i18n-page="home"] .section-head{
    display:block;
    margin-bottom:10px;
  }
  body[data-i18n-page="home"] .section-head h2,
  body[data-i18n-page="home"] .notice h2{
    font-size:24px;
    line-height:1.18;
  }
  body[data-i18n-page="home"] .lead,
  body[data-i18n-page="home"] .card p,
  body[data-i18n-page="home"] .feature-card p,
  body[data-i18n-page="home"] .notice p,
  body[data-i18n-page="home"] .faq-item p{
    font-size:14px;
    line-height:1.5;
  }
  body[data-i18n-page="home"] .eyebrow{
    margin-bottom:10px;
    padding:7px 10px;
    font-size:11px;
  }
  body[data-i18n-page="home"] .hero-actions,
  body[data-i18n-page="home"] .footer-actions,
  body[data-i18n-page="home"] .contact-strip{
    gap:8px;
  }
  body[data-i18n-page="home"] .btn,
  body[data-i18n-page="home"] .tag{
    width:100%;
    max-width:100%;
    white-space:normal;
    overflow-wrap:anywhere;
    text-align:center;
  }
  body[data-i18n-page="home"] .kpi{
    padding:12px;
  }
  body[data-i18n-page="home"] .hero-media{
    min-height:0;
  }
  body[data-i18n-page="home"] .hero-photo{
    height:auto;
    max-height:260px;
    object-fit:contain;
  }
  body[data-i18n-page="home"] .carousel-view{
    border-radius:16px;
  }
  body[data-i18n-page="home"] .carousel-view img{
    height:260px;
    max-width:100%;
    object-fit:contain;
  }
  body[data-i18n-page="home"] .map-frame{
    height:260px;
  }
  body[data-i18n-page="home"] .footer{
    margin-top:14px;
    padding:20px 0;
  }
}
