*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--primary:#F5C518;--secondary:#0A0A0A;--bg:#0A0A0A;--surface:#141414;--surface2:#1C1C1C;--text:#F5F5F5;--muted:#A8A8A8;--border:#2A2A2A;--radius:16px;--shadow:0 20px 60px rgba(0,0,0,.45);--font:'DM Sans',system-ui,sans-serif}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:min(1200px,calc(100% - 2rem));margin-inline:auto}
.container-narrow{width:min(820px,calc(100% - 2rem));margin-inline:auto}

.site-header{position:sticky;top:0;z-index:200;background:rgba(10,10,10,.75);backdrop-filter:blur(16px);border-bottom:1px solid transparent;transition:background .3s,border-color .3s,box-shadow .3s}
.site-header.is-scrolled{background:rgba(10,10,10,.95);border-bottom-color:var(--border);box-shadow:0 8px 32px rgba(0,0,0,.3)}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:72px;gap:1rem}
.logo{display:flex;align-items:center;min-width:0}
.logo-text{font-weight:700;font-size:1.15rem;color:var(--primary);letter-spacing:.02em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.header-mobile-actions{display:none;align-items:center;gap:.45rem;flex-shrink:0}
.header-mobile-cta{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:rgba(245,197,24,.12);border:1px solid rgba(245,197,24,.28);color:var(--primary);transition:.2s}
.header-mobile-cta:active{transform:scale(.96)}
.nav-toggle{display:none;align-items:center;justify-content:center;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:12px;width:44px;height:44px;flex-direction:column;gap:5px;cursor:pointer;transition:.25s;flex-shrink:0}
.nav-toggle span{display:block;width:18px;height:2px;background:var(--text);border-radius:2px;transition:transform .25s,opacity .2s,width .2s}
.nav-toggle.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0;width:0}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.site-nav{display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap}
.site-nav a{color:var(--muted);font-weight:500;font-size:.95rem;transition:.2s}
.site-nav a:hover,.site-nav a.is-active,.site-nav a.btn{color:var(--text)}
.site-nav a.is-active{color:var(--primary)}
.site-nav .btn-primary{padding:.55rem 1rem;border-radius:999px}

/* Mobile sidebar */
.mobile-nav-overlay{position:fixed;inset:0;background:rgba(0,0,0,.62);backdrop-filter:blur(4px);z-index:240;opacity:0;transition:opacity .3s}
.mobile-nav-overlay.is-visible{opacity:1}
.mobile-sidebar{position:fixed;top:0;right:0;width:min(320px,calc(100vw - 3rem));height:100dvh;max-height:100dvh;z-index:250;display:flex;flex-direction:column;background:linear-gradient(180deg,#121212 0%,#0a0a0a 100%);border-left:1px solid rgba(245,197,24,.18);box-shadow:-24px 0 80px rgba(0,0,0,.55);transform:translateX(105%);transition:transform .32s cubic-bezier(.4,0,.2,1);padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}
.mobile-sidebar.is-open{transform:translateX(0)}
.mobile-sidebar__head{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.25rem 1.15rem 1rem;border-bottom:1px solid var(--border)}
.mobile-sidebar__brand{min-width:0}
.mobile-sidebar__logo{display:block;font-weight:700;font-size:1.05rem;color:var(--primary);margin-bottom:.25rem}
.mobile-sidebar__tagline{display:block;color:var(--muted);font-size:.78rem;line-height:1.45}
.mobile-sidebar__close{width:42px;height:42px;border-radius:12px;border:1px solid var(--border);background:rgba(255,255,255,.04);color:var(--text);display:grid;place-items:center;cursor:pointer;flex-shrink:0;transition:.2s}
.mobile-sidebar__close:active{transform:scale(.95);border-color:rgba(245,197,24,.35)}
.mobile-sidebar__nav{flex:1;overflow-y:auto;padding:1rem .85rem;-webkit-overflow-scrolling:touch}
.mobile-sidebar__link{display:flex;align-items:center;gap:.85rem;padding:.9rem 1rem;border-radius:14px;color:var(--text);font-weight:600;font-size:.98rem;border:1px solid transparent;transition:.2s;margin-bottom:.35rem;min-height:52px}
.mobile-sidebar__link:active{background:rgba(255,255,255,.04)}
.mobile-sidebar__link.is-active{background:rgba(245,197,24,.1);border-color:rgba(245,197,24,.25);color:var(--primary)}
.mobile-sidebar__icon{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--muted);flex-shrink:0}
.mobile-sidebar__link.is-active .mobile-sidebar__icon{background:rgba(245,197,24,.15);border-color:rgba(245,197,24,.3);color:var(--primary)}
.mobile-sidebar__foot{padding:1rem 1.15rem 1.25rem;border-top:1px solid var(--border);background:rgba(0,0,0,.25)}
.mobile-sidebar__cta{margin-bottom:.85rem;min-height:50px;font-size:1rem}
.mobile-sidebar__contacts{display:grid;gap:.55rem}
.mobile-sidebar__contacts a{display:inline-flex;align-items:center;gap:.55rem;color:var(--muted);font-size:.86rem;font-weight:500;padding:.35rem 0;min-height:36px}
.mobile-sidebar__contacts a:active{color:var(--primary)}
body.mobile-nav-open{overflow:hidden;touch-action:none}

@media (min-width:769px){
  .mobile-sidebar,.mobile-nav-overlay,.header-mobile-actions{display:none!important}
}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.85rem 1.4rem;border-radius:999px;font-weight:600;border:1px solid transparent;cursor:pointer;transition:.2s;font-size:.95rem}
.btn-primary{background:var(--primary);color:#111}
.btn-primary:hover{filter:brightness(1.05);transform:translateY(-1px)}
.btn-outline{border-color:var(--border);color:var(--text);background:transparent}
.btn-outline:hover{border-color:var(--primary);color:var(--primary)}
.btn-block{width:100%}
.btn-sm{padding:.45rem .9rem;font-size:.85rem}
.btn-lg{padding:1rem 1.75rem;font-size:1rem}
.btn-glass{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);color:var(--text);backdrop-filter:blur(8px)}
.btn-glass:hover{border-color:var(--primary);color:var(--primary);background:rgba(245,197,24,.08)}
.link-arrow{display:inline-flex;align-items:center;gap:.4rem;color:var(--primary);font-weight:600;font-size:.95rem;margin-top:1rem;transition:.2s}
.link-arrow:hover{gap:.65rem}

.hero{position:relative;min-height:78vh;display:grid;align-items:end;padding:4rem 0 3rem;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:linear-gradient(135deg,#111 0%,#1a1500 50%,#0a0a0a 100%)}
.hero-bg img{width:100%;height:100%;object-fit:cover;opacity:.45}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.2) 0%,rgba(10,10,10,.95) 85%)}
.hero-content{position:relative;z-index:1;max-width:760px}
.hero-tag{display:inline-block;color:var(--primary);font-weight:600;font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1rem}
.hero h1{font-size:clamp(2rem,6vw,3.6rem);line-height:1.08;margin-bottom:1rem;font-weight:700}
.hero p{color:var(--muted);font-size:1.05rem;margin-bottom:1.75rem;max-width:560px}
.hero-actions{display:flex;flex-wrap:wrap;gap:.75rem}

.section{padding:4rem 0}
.section-dark{background:var(--surface)}
.section-head{margin-bottom:2rem}
.section-head h2{font-size:clamp(1.6rem,4vw,2.2rem);margin-bottom:.35rem}
.section-head p{color:var(--muted)}
.section-cta{text-align:center;margin-top:2rem}

.page-hero{padding:3.5rem 0 2rem;border-bottom:1px solid var(--border);background:linear-gradient(180deg,#121212,#0a0a0a)}
.page-hero h1{font-size:clamp(1.8rem,5vw,2.8rem)}

.listing-grid,.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.35rem}
.listing-grid--catalog{margin-top:.25rem}
.listing-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;overflow:hidden;transition:.25s;height:100%}
.listing-card:hover{transform:translateY(-4px);border-color:rgba(245,197,24,.35);box-shadow:var(--shadow)}
.listing-card-link{display:flex;flex-direction:column;height:100%}
.listing-card-image{position:relative;aspect-ratio:4/3;background:#222;overflow:hidden;flex-shrink:0}
.listing-card-image img,.listing-card-image .media-placeholder{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .35s}
.listing-card:hover .listing-card-image img{transform:scale(1.04)}
.listing-card-price{position:absolute;left:.85rem;bottom:.85rem;padding:.45rem .75rem;border-radius:999px;background:rgba(10,10,10,.82);border:1px solid rgba(245,197,24,.28);color:var(--primary);font-weight:700;font-size:.95rem;backdrop-filter:blur(8px)}
.listing-card-price small{font-size:.72rem;color:#ddd;font-weight:500}
.listing-placeholder{background:linear-gradient(135deg,#222,#111);aspect-ratio:4/3}
.listing-placeholder.large{min-height:0;aspect-ratio:16/10;border-radius:18px;overflow:hidden}
.badge,.badge-featured{position:absolute;top:.75rem;left:.75rem;z-index:2;background:var(--primary);color:#111;font-size:.75rem;font-weight:700;padding:.3rem .65rem;border-radius:999px}
.listing-card-body{padding:1.15rem 1.2rem 1.25rem;display:flex;flex-direction:column;flex:1}
.listing-card-body h3{font-size:1.08rem;margin:.2rem 0 .45rem;line-height:1.3}
.listing-location{color:var(--primary);font-size:.78rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;margin-bottom:.15rem}
.listing-desc{color:var(--muted);font-size:.88rem;margin-bottom:1rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.55;flex:1}
.listing-card-foot{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-top:auto;padding-top:.85rem;border-top:1px solid var(--border)}
.listing-meta{display:flex;gap:.85rem;color:var(--muted);font-size:.82rem}
.listing-card-cta{color:var(--primary);font-size:.82rem;font-weight:700;white-space:nowrap}
.listing-price{font-size:1.25rem;font-weight:700;color:var(--primary)}
.listing-price small{font-size:.75rem;color:var(--muted);font-weight:500}

/* Listings index */
.listings-hero__inner{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;flex-wrap:wrap}
.listings-hero__copy{max-width:640px}
.listings-hero__stats{display:grid;grid-template-columns:repeat(3,minmax(90px,1fr));gap:.75rem;min-width:min(100%,320px)}
.listings-stat{padding:.85rem 1rem;border-radius:14px;background:rgba(255,255,255,.03);border:1px solid var(--border);text-align:center}
.listings-stat strong{display:block;color:var(--primary);font-size:1.15rem}
.listings-stat span{color:var(--muted);font-size:.76rem}
.listings-toolbar{margin-bottom:1.25rem;padding:.85rem 1rem;border-radius:12px;background:rgba(255,255,255,.02);border:1px solid var(--border);color:var(--muted);font-size:.9rem}
.listings-toolbar strong{color:var(--text)}
.listings-cta{margin-top:2.5rem;padding:1.75rem 1.5rem;border-radius:18px;display:flex;align-items:center;justify-content:space-between;gap:1.25rem;flex-wrap:wrap;background:linear-gradient(135deg,#1a1500,#111);border:1px solid rgba(245,197,24,.18)}
.listings-cta h2{font-size:clamp(1.2rem,3vw,1.5rem);margin-bottom:.35rem}
.listings-cta p{color:var(--muted);max-width:480px;font-size:.92rem}
.pagination__nav{padding:.5rem 1rem!important}
.empty-state__icon{display:block;font-size:2.5rem;margin-bottom:.75rem}

.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1rem}
.feature-item{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}
.feature-icon{color:var(--primary);font-size:1.2rem;display:block;margin-bottom:.5rem}

.blog-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:.25s}
.blog-card:hover{border-color:rgba(245,197,24,.3)}
.blog-card-image{position:relative;aspect-ratio:16/10;background:#222;overflow:hidden}
.blog-card-image img,.blog-card-image .media-placeholder{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.blog-card-body{padding:1rem}
.blog-cat{color:var(--primary);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em}
.blog-detail h1{font-size:clamp(1.8rem,4vw,2.6rem);margin:.5rem 0 1rem}
.blog-meta{color:var(--muted);margin-bottom:1.5rem}
.blog-cover{border-radius:var(--radius);margin-bottom:1.5rem;width:100%;max-height:420px;object-fit:cover}

.listing-detail{padding:1.5rem 0 5rem}
.detail-breadcrumb{display:flex;flex-wrap:wrap;align-items:center;gap:.45rem;margin-bottom:1.25rem;color:var(--muted);font-size:.86rem}
.detail-breadcrumb a{color:var(--muted);transition:.2s}
.detail-breadcrumb a:hover{color:var(--primary)}
.detail-breadcrumb span[aria-current="page"]{color:var(--text);max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.detail-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,380px);gap:2rem;align-items:start}
.detail-main{min-width:0}
.detail-gallery{margin-bottom:1.5rem}
.gallery-main{position:relative;border-radius:18px;overflow:hidden;border:1px solid var(--border);background:#111;aspect-ratio:16/10}
.gallery-main--carousel{isolation:isolate}
.gallery-slide{position:absolute;inset:0;opacity:0;transition:opacity .45s ease;pointer-events:none}
.gallery-slide.is-active{opacity:1;pointer-events:auto;z-index:1}
.gallery-slide img{width:100%;height:100%;object-fit:cover;display:block}
.gallery-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.18);background:rgba(10,10,10,.72);color:#fff;font-size:1.75rem;line-height:1;display:grid;place-items:center;cursor:pointer;backdrop-filter:blur(8px);transition:.2s}
.gallery-nav:hover{border-color:var(--primary);color:var(--primary)}
.gallery-nav--prev{left:.85rem}
.gallery-nav--next{right:.85rem}
.gallery-counter{position:absolute;bottom:.85rem;right:.85rem;z-index:3;padding:.35rem .7rem;border-radius:999px;background:rgba(10,10,10,.78);border:1px solid var(--border);color:#ddd;font-size:.78rem;font-weight:600;backdrop-filter:blur(8px)}
.gallery-main img{width:100%;height:100%;object-fit:cover;display:block}
.gallery-main--empty{min-height:280px}
.gallery-main--empty .media-placeholder{position:absolute;inset:0;min-height:100%}
.gallery-count{position:absolute;top:.85rem;right:.85rem;padding:.35rem .7rem;border-radius:999px;background:rgba(10,10,10,.78);border:1px solid var(--border);color:#ddd;font-size:.75rem;font-weight:600;backdrop-filter:blur(8px)}
.gallery-thumbs{display:flex;gap:.55rem;margin-top:.75rem;overflow-x:auto;padding-bottom:.35rem;scrollbar-width:thin}
.thumb-btn{border:2px solid transparent;border-radius:12px;overflow:hidden;padding:0;background:none;cursor:pointer;flex:0 0 84px;height:64px;transition:.2s}
.thumb-btn img{width:100%;height:100%;object-fit:cover}
.thumb-btn.active,.thumb-btn:hover{border-color:var(--primary)}
.detail-head{margin-bottom:1.25rem}
.detail-location{display:inline-block;color:var(--primary);font-weight:700;font-size:.78rem;letter-spacing:.08em;text-transform:uppercase;margin-bottom:.45rem}
.detail-content h1{font-size:clamp(1.7rem,4vw,2.35rem);margin:.2rem 0 .65rem;line-height:1.15}
.lead{color:var(--muted);font-size:1rem;line-height:1.65;max-width:720px}
.detail-summary{display:grid;grid-template-columns:auto 1fr;gap:1rem;align-items:stretch;margin-bottom:1.25rem;padding:1rem;border-radius:16px;background:rgba(255,255,255,.02);border:1px solid var(--border)}
.detail-price-box{display:flex;flex-direction:column;justify-content:center;padding:.85rem 1.1rem;border-radius:14px;background:linear-gradient(135deg,rgba(245,197,24,.12),rgba(245,197,24,.04));border:1px solid rgba(245,197,24,.22);min-width:140px}
.detail-price-label{display:block;color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:.15rem}
.detail-price{font-size:1.55rem;font-weight:700;color:var(--primary);line-height:1}
.detail-price small{font-size:.78rem;color:var(--muted);font-weight:500}
.specs-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.55rem}
.specs-grid div{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:.7rem .5rem;text-align:center}
.specs-grid strong{display:block;font-size:1.05rem}
.specs-grid span{color:var(--muted);font-size:.76rem}
.amenities{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.5rem}
.chip{border:1px solid var(--border);padding:.4rem .75rem;border-radius:999px;font-size:.82rem;color:var(--muted);background:rgba(255,255,255,.02)}
.chip--gold{border-color:rgba(245,197,24,.25);color:#eee;background:rgba(245,197,24,.08)}
.amenity-showcase{margin-bottom:1.5rem}
.amenity-showcase h2{font-size:1.15rem;margin-bottom:.85rem}
.amenity-showcase__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.65rem}
.amenity-showcase__item{display:flex;align-items:center;gap:.65rem;padding:.75rem .85rem;border-radius:12px;background:var(--surface);border:1px solid var(--border);font-size:.88rem;color:#ddd}
.amenity-showcase__icon{display:grid;place-items:center;width:36px;height:36px;border-radius:10px;background:rgba(245,197,24,.1);color:var(--primary);flex-shrink:0}
.amenity-showcase__icon .amenity-icon{width:20px;height:20px}
.detail-section{margin-bottom:1.5rem}
.detail-section h2{font-size:1.15rem;margin-bottom:.75rem}
.detail-section--card{padding:1.15rem 1.2rem;border-radius:16px;background:var(--surface);border:1px solid var(--border)}
.content-block{color:#ddd;line-height:1.75;font-size:.95rem}
.content-block h2,.content-block h3{margin:1rem 0 .5rem;color:var(--text)}
.check-list,.rule-list{padding-left:1.2rem;color:var(--muted);display:grid;gap:.35rem}
.check-list li,.rule-list li{margin:0;line-height:1.55}
.detail-sidebar{position:relative}
.reservation-box{position:sticky;top:92px;background:linear-gradient(180deg,#161616,#111);border:1px solid rgba(245,197,24,.18);border-radius:18px;padding:1.35rem;box-shadow:var(--shadow)}
.reservation-box__head{margin-bottom:1rem}
.reservation-box__head h3{margin-bottom:.25rem;font-size:1.1rem}
.reservation-box__head p{color:var(--muted);font-size:.82rem}
.reservation-box__price{display:flex;align-items:baseline;gap:.35rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}
.reservation-box__price strong{font-size:1.45rem;color:var(--primary)}
.reservation-box__price span{color:var(--muted);font-size:.85rem}
.reservation-wa{margin-top:.65rem}
.detail-mobile-bar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:180;padding:.85rem 1rem calc(.85rem + env(safe-area-inset-bottom));background:rgba(10,10,10,.96);border-top:1px solid var(--border);backdrop-filter:blur(16px);align-items:center;justify-content:space-between;gap:1rem;box-shadow:0 -12px 40px rgba(0,0,0,.35)}
.detail-mobile-bar__price{display:flex;align-items:baseline;gap:.25rem}
.detail-mobile-bar__price strong{color:var(--primary);font-size:1.2rem}
.detail-mobile-bar__price span{color:var(--muted);font-size:.82rem}
.detail-mobile-bar .btn{min-width:140px;padding:.85rem 1.2rem}
.form-group{margin-bottom:.9rem}
.form-group label{display:block;font-size:.85rem;color:var(--muted);margin-bottom:.35rem}
.form-group input,.form-group textarea,.form-group select{width:100%;background:#0f0f0f;border:1px solid var(--border);color:var(--text);border-radius:12px;padding:.75rem .85rem;font:inherit}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.hp-field{position:absolute;left:-9999px;height:0;overflow:hidden}
.alert{padding:.85rem 1rem;border-radius:12px;margin-bottom:1rem;font-size:.9rem}
.alert-error{background:rgba(220,53,69,.15);border:1px solid rgba(220,53,69,.35);color:#ffb4bc}

.site-footer{border-top:1px solid var(--border);padding:3rem 0 1rem;margin-top:2rem;background:#080808}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:2rem;margin-bottom:2rem}
.footer-brand p{color:var(--muted);margin-top:.75rem;max-width:360px}
.site-footer h4{margin-bottom:.75rem;font-size:.95rem}
.site-footer ul{list-style:none}
.site-footer li{margin:.4rem 0;color:var(--muted)}
.site-footer a:hover{color:var(--primary)}
.footer-bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;color:var(--muted);font-size:.85rem;padding-top:1rem;border-top:1px solid var(--border)}

.floating-actions{position:fixed;right:1rem;bottom:1rem;z-index:120;display:flex;flex-direction:column;gap:.65rem}
.fab{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;color:#fff;box-shadow:0 8px 24px rgba(0,0,0,.35);transition:.2s}
.fab:hover{transform:scale(1.06)}
.fab-wa{background:#25D366}
.fab-ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}

.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1rem}
.gallery-item{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:var(--surface)}
.gallery-item img{width:100%;aspect-ratio:4/3;object-fit:cover}
.gallery-item figcaption{padding:.75rem;color:var(--muted);font-size:.85rem}

.contact-grid{display:grid;gap:2rem}
.contact-cards{display:grid;gap:1rem}
.contact-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem}
.map-embed iframe{width:100%;min-height:320px;border:0;border-radius:var(--radius)}

.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1rem;margin-bottom:.75rem}
.faq-item summary{cursor:pointer;font-weight:600;list-style:none}
.faq-item summary::-webkit-details-marker{display:none}
.faq-answer{color:var(--muted);margin-top:.75rem}

.pagination{display:flex;gap:.5rem;justify-content:center;margin-top:2rem;flex-wrap:wrap}
.pagination a{padding:.5rem .85rem;border:1px solid var(--border);border-radius:999px;color:var(--muted)}
.pagination a.active,.pagination a:hover{border-color:var(--primary);color:var(--primary)}

.error-page,.maintenance{min-height:60vh;display:grid;place-items:center;text-align:center;padding:3rem 1rem}
.error-page h1{font-size:4rem;color:var(--primary)}
.success-hero .success-icon{width:72px;height:72px;border-radius:50%;background:var(--primary);color:#111;display:grid;place-items:center;font-size:2rem;margin:0 auto 1rem;font-weight:700}
.success-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;display:grid;gap:.75rem}

.section-label{display:inline-block;color:var(--primary);font-size:.78rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:.5rem}
.page-hero p{color:var(--muted);margin-top:.5rem;max-width:560px}
.page-hero--compact{padding:2.75rem 0 1.75rem}
.hero-stats{display:flex;gap:1.5rem;margin-top:2rem;flex-wrap:wrap}
.hero-stats div{min-width:90px}
.hero-stats strong{display:block;font-size:1.35rem;color:var(--primary)}
.hero-stats span{color:var(--muted);font-size:.82rem}
.cta-banner{background:linear-gradient(135deg,#1a1500,#0f0f0f);border-block:1px solid var(--border)}
.cta-banner-inner{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.cta-banner h2{font-size:clamp(1.4rem,3vw,2rem);margin-bottom:.35rem}
.cta-banner p{color:var(--muted)}
.cta-banner-actions{display:flex;gap:.75rem;flex-wrap:wrap}
.about-grid{display:grid;grid-template-columns:1.4fr .9fr;gap:2rem;align-items:start}
.about-aside{display:grid;gap:1rem}
.info-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}
.info-card h3{margin-bottom:.75rem;font-size:1rem}
.stats-inline{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;text-align:center}
.stats-inline strong{display:block;font-size:1.5rem;color:var(--primary)}
.stats-inline span{color:var(--muted);font-size:.82rem}
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}
.contact-info .intro-block{margin-bottom:1.5rem}
.contact-icon{font-size:1.4rem;display:block;margin-bottom:.35rem}
.contact-actions{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:1.25rem}
.map-embed--styled{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);margin-bottom:1rem}
.map-embed--styled iframe{width:100%;min-height:280px;border:0;display:block}
.map-placeholder{background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius);padding:2rem;text-align:center;color:var(--muted);margin-bottom:1rem}
.gallery-grid--masonry{grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.gallery-item--clickable{cursor:pointer;transition:.25s}
.gallery-item--clickable:hover{transform:scale(1.02);border-color:rgba(245,197,24,.35)}
.gallery-item figcaption small{display:block;color:var(--primary);font-size:.78rem;margin-top:.25rem}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.92);z-index:200;display:grid;place-items:center;padding:1rem}
.lightbox img{max-width:min(1100px,100%);max-height:90vh;border-radius:12px}
.lightbox-close{position:absolute;top:1rem;right:1rem;background:none;border:0;color:#fff;font-size:2.5rem;cursor:pointer;line-height:1}
.faq-list{display:grid;gap:.75rem}
.faq-cta{text-align:center;margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border)}
.faq-cta p{color:var(--muted);margin-bottom:1rem}
.legal-content{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}
.empty-state{text-align:center;padding:3rem 1rem;background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius)}
.empty-state h3{margin-bottom:.5rem}
.empty-state p{color:var(--muted)}
.blog-date{display:block;margin-top:.75rem;color:var(--muted);font-size:.82rem}
.muted{color:var(--muted);font-size:.9rem;margin-top:.35rem}
.listing-placeholder{background:linear-gradient(135deg,#1a1500 0%,#111 50%,#0a0a0a 100%);width:100%;height:100%;min-height:180px}

/* ===== HOME PAGE ===== */
.home-page{overflow-x:hidden}
.media-placeholder{position:relative;display:grid;place-items:center;gap:.5rem;width:100%;height:100%;min-height:0;background:linear-gradient(145deg,#2a2200 0%,#1a1500 35%,#141414 70%,#0a0a0a 100%);color:var(--primary);text-align:center}
.media-placeholder::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 35%,rgba(245,197,24,.14),transparent 55%);pointer-events:none}
.media-placeholder span{font-size:clamp(2.5rem,8vw,3.5rem);line-height:1;position:relative;z-index:1;filter:drop-shadow(0 8px 24px rgba(0,0,0,.35))}
.media-placeholder small{color:#ddd;font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;position:relative;z-index:1}
.media-placeholder--card{min-height:0;aspect-ratio:auto}
.media-placeholder--sm{min-height:0}

.home-hero{position:relative;padding:calc(72px + 2.5rem) 0 3.5rem;overflow:hidden;background:#0a0a0a;min-height:520px}
.home-hero__bg{position:absolute;inset:0;pointer-events:none}
.home-hero__img,.home-hero__fallback{width:100%;height:100%;object-fit:cover}
.home-hero__img{opacity:.32}
.home-hero__fallback{background:radial-gradient(ellipse at 20% 20%,rgba(245,197,24,.12),transparent 50%),linear-gradient(135deg,#121212,#0a0a0a 60%,#151000)}
.home-hero__shade{position:absolute;inset:0;background:linear-gradient(90deg,rgba(10,10,10,.92) 0%,rgba(10,10,10,.75) 45%,rgba(10,10,10,.55) 100%)}
.home-hero__grid{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:2.5rem;align-items:center}
.home-hero__eyebrow{display:inline-block;margin-bottom:1rem;padding:.35rem .8rem;border-radius:999px;background:rgba(245,197,24,.12);border:1px solid rgba(245,197,24,.28);color:var(--primary);font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.home-hero h1{margin-bottom:1rem;padding-top:.15rem}
.home-hero__title-main{display:block;font-size:clamp(2rem,5vw,3.4rem);font-weight:700;line-height:1.15;letter-spacing:-.02em;color:#fff}
.home-hero__desc{color:var(--muted);font-size:1.05rem;line-height:1.75;max-width:540px;margin-bottom:1.5rem}
.home-hero__btns{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem}
.home-hero__pills{display:flex;flex-wrap:wrap;gap:.55rem;list-style:none}
.home-hero__pills li{padding:.4rem .75rem;border-radius:999px;background:rgba(255,255,255,.04);border:1px solid var(--border);color:var(--muted);font-size:.78rem}

.spotlight-card{display:block;border-radius:20px;overflow:hidden;background:var(--surface);border:1px solid rgba(245,197,24,.22);box-shadow:0 24px 60px rgba(0,0,0,.45);transition:.3s}
.spotlight-card:hover{transform:translateY(-4px);border-color:rgba(245,197,24,.45)}
.spotlight-card__media{position:relative;aspect-ratio:16/10;overflow:hidden;background:#111}
.spotlight-card__media img,.spotlight-card__media .media-placeholder{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.spotlight-card__media .media-placeholder{min-height:0;aspect-ratio:auto}
.spotlight-card__label{position:absolute;top:.85rem;left:.85rem;padding:.28rem .65rem;border-radius:999px;background:var(--primary);color:#111;font-size:.68rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.spotlight-card__body{padding:1.15rem 1.25rem 1.25rem}
.spotlight-card__body h3{font-size:1.1rem;margin-bottom:.25rem}
.spotlight-card__body p{color:var(--muted);font-size:.86rem;margin-bottom:.65rem}
.spotlight-card__price{font-size:1.3rem;font-weight:700;color:var(--primary)}
.spotlight-card__price small{font-size:.75rem;color:var(--muted);font-weight:500}

.home-stats{border-block:1px solid var(--border);background:var(--surface);padding:1.75rem 0}
.home-stats__row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;text-align:center}
.home-stat strong{display:block;font-size:clamp(1.4rem,3vw,1.9rem);font-weight:700;color:var(--primary)}
.home-stat span{color:var(--muted);font-size:.84rem}

.section-head--center{text-align:center;max-width:640px;margin-inline:auto}
.section-head--center p{margin-top:.5rem;color:var(--muted)}
.listing-grid--home{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));justify-items:stretch}

.home-experience{background:linear-gradient(180deg,var(--bg),#100e00,var(--bg))}
.home-experience__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:2.5rem;align-items:start}
.home-experience__intro h2{font-size:clamp(1.7rem,3.5vw,2.3rem);line-height:1.15;margin:.65rem 0 1rem}
.home-experience__intro p{color:var(--muted);margin-bottom:1.25rem;line-height:1.7}
.home-experience__cards{display:grid;gap:.85rem}
.exp-card{display:grid;grid-template-columns:auto 1fr;gap:1rem;padding:1.1rem 1.15rem;border-radius:14px;background:var(--surface);border:1px solid var(--border)}
.exp-card span{width:42px;height:42px;border-radius:10px;background:var(--primary);color:#111;display:grid;place-items:center;font-weight:800;font-size:.82rem}
.exp-card h3{font-size:.98rem;margin-bottom:.2rem}
.exp-card p{color:var(--muted);font-size:.86rem}

.home-steps__row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:.5rem}
.step-card{padding:1.75rem 1.25rem;border-radius:16px;background:rgba(255,255,255,.02);border:1px solid var(--border);text-align:center}
.step-card__num{width:52px;height:52px;margin:0 auto .85rem;border-radius:50%;background:var(--primary);color:#111;font-weight:800;font-size:1.15rem;display:grid;place-items:center}
.step-card h3{margin-bottom:.4rem;font-size:1rem}
.step-card p{color:var(--muted);font-size:.88rem}

.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
.review-card{margin:0;padding:1.35rem;border-radius:16px;background:var(--surface);border:1px solid var(--border)}
.review-card p{color:#ddd;line-height:1.65;margin-bottom:.85rem;font-style:italic}
.review-card footer{color:var(--primary);font-size:.82rem;font-weight:600;font-style:normal}

.home-cta{padding:4rem 0}
.home-cta__box{display:flex;align-items:center;justify-content:space-between;gap:2rem;flex-wrap:wrap;padding:2.5rem;border-radius:20px;background:linear-gradient(135deg,#1a1500,#111);border:1px solid rgba(245,197,24,.22)}
.home-cta__box h2{font-size:clamp(1.5rem,3vw,2rem);line-height:1.2;margin:.45rem 0 .65rem}
.home-cta__box p{color:var(--muted);max-width:480px}
.home-cta__btns{display:flex;gap:.75rem;flex-wrap:wrap}


@media (max-width:1024px){
  .home-hero__grid,.home-experience__grid{grid-template-columns:1fr}
  .home-stats__row{grid-template-columns:repeat(2,1fr)}
  .home-steps__row,.review-grid{grid-template-columns:1fr}
}
@media (max-width:640px){
  .home-hero{padding:calc(72px + 1.75rem) 0 2.5rem;min-height:auto}
  .home-stats__row{grid-template-columns:1fr 1fr}
  .home-cta__box{padding:1.5rem}
}

@media (max-width:900px){
  .detail-layout{grid-template-columns:1fr}
  .reservation-box{position:static}
  .detail-summary{grid-template-columns:1fr}
  .detail-price-box{flex-direction:row;align-items:center;justify-content:space-between;min-width:0}
  .listings-hero__stats{grid-template-columns:repeat(3,1fr);width:100%}
  .detail-grid{grid-template-columns:1fr}
  .reservation-box{position:static}
  .footer-grid{grid-template-columns:1fr}
  .specs-grid{grid-template-columns:repeat(2,1fr)}
  .about-grid,.contact-layout{grid-template-columns:1fr}
}
@media (max-width:768px){
  .site-nav--desktop{display:none}
  .header-mobile-actions{display:flex}
  .nav-toggle{display:flex}
  .hero{min-height:68vh}
  .floating-actions{right:.75rem;bottom:calc(.75rem + env(safe-area-inset-bottom))}
  .section{padding:3rem 0}
  .container{width:min(1200px,calc(100% - 1.25rem))}
  .home-hero__grid{gap:1.5rem}
  .home-hero__btns,.home-hero__pills{gap:.55rem}
  .home-hero__btns .btn,.home-cta__btns .btn{flex:1 1 calc(50% - .35rem);min-width:0;padding:.85rem 1rem}
  .home-hero__copy{text-align:left}
  .spotlight-card{border-radius:16px}
  .home-stats__row{gap:.75rem}
  .home-stat{padding:.35rem .25rem}
  .home-cta__box{flex-direction:column;align-items:stretch;text-align:center;padding:1.75rem 1.25rem}
  .home-cta__btns{width:100%;justify-content:center}
  .footer-grid{gap:1.5rem}
  .site-footer{padding:2.5rem 0 1rem;margin-top:1rem}
  .page-hero{padding:calc(72px + 1.5rem) 0 1.5rem}
  .listing-detail{padding:1rem 0 calc(5.5rem + env(safe-area-inset-bottom))}
  .detail-mobile-bar{display:flex}
  .floating-actions{bottom:calc(5.5rem + env(safe-area-inset-bottom))}
  .detail-breadcrumb{font-size:.8rem}
  .detail-breadcrumb span[aria-current="page"]{max-width:160px}
  .gallery-main{aspect-ratio:4/3;border-radius:16px}
  .gallery-nav{width:40px;height:40px;font-size:1.5rem}
  .amenity-showcase__grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .detail-content h1{font-size:1.55rem}
  .listings-hero__inner{align-items:stretch}
  .listings-cta{flex-direction:column;align-items:stretch;text-align:center}
  .listings-cta .btn{width:100%}
  .listing-grid,.listing-grid--catalog{grid-template-columns:1fr}
  .detail-grid{gap:1.25rem}
  .reservation-box{padding:1rem;border-radius:16px}
  .form-row{grid-template-columns:1fr}
}
