:root{
  --bg:#f6f1e8;
  --bg-soft:#efe6da;
  --surface:#fffdf9;
  --surface-2:#f3ece2;
  --ink:#1f1a17;
  --muted:#685b51;
  --line:rgba(31,26,23,.10);
  --line-strong:rgba(31,26,23,.18);
  --brand:#b66a2c;
  --brand-2:#7f4b22;
  --deep:#191512;
  --deep-soft:#241d18;
  --white:#fffdfa;
  --shadow:0 18px 50px rgba(41,26,15,.10);
  --shadow-lg:0 28px 80px rgba(41,26,15,.16);
  --radius:26px;
  --container:1240px;
  --topbar-h:86px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Manrope",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at top left, rgba(182,106,44,.10), transparent 30%),
    linear-gradient(180deg,#f8f3ec 0%,#f2ebe1 54%,#f7f3ec 100%);
  line-height:1.65;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,textarea{font:inherit}
.container{width:min(calc(100% - 32px),var(--container));margin:0 auto}
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}

body::before,
body::after{
  content:"";position:fixed;inset:auto auto 12% -90px;width:240px;height:240px;border-radius:50%;
  background:radial-gradient(circle, rgba(182,106,44,.10), transparent 70%);pointer-events:none;filter:blur(10px);z-index:-1
}
body::after{inset:10% -80px auto auto;width:280px;height:280px;background:radial-gradient(circle, rgba(79,59,44,.08), transparent 72%)}

.topbar{
  position:sticky;top:0;z-index:100;
  backdrop-filter:blur(22px) saturate(140%);
  background:rgba(247,241,232,.72);
  border-bottom:1px solid rgba(31,26,23,.08);
}
.topbar__inner{min-height:var(--topbar-h);display:flex;align-items:center;justify-content:space-between;gap:28px}
.brand{display:flex;align-items:center;gap:0;min-width:0;max-width:min(46vw,360px)}
.brand__logo{display:block;height:74px!important;max-width:min(46vw,340px);width:auto;object-fit:contain;padding:0;border-radius:0;background:none;border:0;box-shadow:none;filter:drop-shadow(0 10px 24px rgba(0,0,0,.42)) drop-shadow(0 2px 8px rgba(0,0,0,.28))}
.brand__mark{
  width:42px;height:42px;display:grid;place-items:center;border-radius:14px;
  background:linear-gradient(135deg,var(--brand),#e0ab6c);color:#fff;font-size:18px;
  box-shadow:0 12px 28px rgba(182,106,44,.24)
}
.brand__text{display:none}
.nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}
.nav a{
  position:relative;padding:10px 14px;border-radius:999px;font-size:.95rem;font-weight:600;color:rgba(31,26,23,.78);
  transition:.28s ease
}
.nav a:hover{background:rgba(31,26,23,.05);color:var(--ink)}
.topbar__right{display:flex;align-items:center;gap:12px}
.hamburger{display:none;align-items:center;justify-content:center;flex-direction:column;gap:5px;padding:0;border:0;background:transparent;width:48px;height:48px;cursor:pointer;position:relative;z-index:130;-webkit-tap-highlight-color:transparent}
.hamburger::before{content:"";position:absolute;inset:4px;border-radius:15px;background:linear-gradient(180deg,rgba(21,17,14,.88),rgba(33,26,22,.72));border:1px solid rgba(255,255,255,.14);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 14px 30px rgba(0,0,0,.24);transition:transform .28s ease, box-shadow .28s ease, background .28s ease}
.hamburger span{position:relative;display:block;width:20px;height:2px;background:#fff;border-radius:999px;box-shadow:0 1px 3px rgba(0,0,0,.30);transition:transform .28s ease, opacity .2s ease, width .2s ease, background .2s ease}
.hamburger:hover::before,.hamburger:focus-visible::before{transform:translateY(-1px);box-shadow:0 18px 36px rgba(0,0,0,.28)}
.hamburger[aria-expanded="true"]::before{background:linear-gradient(180deg,rgba(28,22,18,.94),rgba(18,14,11,.82))}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0;width:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{display:none;position:fixed;left:14px;right:14px;top:calc(var(--topbar-h) - 6px);padding:16px;z-index:120;border-radius:26px;background:linear-gradient(180deg,rgba(28,22,18,.96),rgba(17,13,11,.94));border:1px solid rgba(255,255,255,.10);box-shadow:0 28px 70px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.05);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);overflow:hidden}
.mobile-nav::before{content:"";position:absolute;inset:0 0 auto 0;height:72px;background:linear-gradient(180deg,rgba(255,255,255,.09),transparent);pointer-events:none}
.mobile-nav::after{content:"";position:fixed;inset:0;background:rgba(8,6,5,.36);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:-1}
.mobile-nav a{position:relative;display:flex;align-items:center;justify-content:space-between;padding:16px 18px;margin-top:10px;background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.04));border:1px solid rgba(255,255,255,.08);border-radius:18px;font-weight:800;letter-spacing:.01em;color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.05);transition:transform .22s ease, background .22s ease, border-color .22s ease}
.mobile-nav a::after{content:"›";font-size:1.08rem;line-height:1;color:rgba(240,197,143,.88);transition:transform .22s ease,color .22s ease}
.mobile-nav a:hover,.mobile-nav a:focus-visible{transform:translateX(2px);background:linear-gradient(180deg,rgba(255,255,255,.12),rgba(255,255,255,.06));border-color:rgba(240,197,143,.24)}
.mobile-nav a:hover::after,.mobile-nav a:focus-visible::after{transform:translateX(2px);color:#f0c58f}
.mobile-nav a:first-child{margin-top:0}
.mobile-nav:not([hidden]){display:block;animation:mobileNavIn .26s cubic-bezier(.2,.8,.2,1)}
.mobile-nav[hidden]{display:none!important}
body.menu-open{overflow:hidden}
body.menu-open .topbar{background:rgba(16,12,10,.82);border-bottom-color:rgba(255,255,255,.07)}
@keyframes mobileNavIn{from{opacity:0;transform:translateY(-12px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}

.btn{
  --btn-bg:var(--deep);--btn-ink:var(--white);--btn-border:transparent;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:54px;padding:0 24px;border-radius:999px;border:1px solid var(--btn-border);
  background:var(--btn-bg);color:var(--btn-ink);font-weight:700;letter-spacing:.01em;
  box-shadow:0 14px 34px rgba(25,21,18,.12);transition:transform .22s ease, box-shadow .22s ease, background .22s ease, border-color .22s ease;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(25,21,18,.16)}
.btn--primary{--btn-bg:linear-gradient(135deg,var(--brand) 0%,#d09151 100%);--btn-ink:#fff}
.btn--ghost{--btn-bg:rgba(255,255,255,.55);--btn-ink:var(--ink);--btn-border:rgba(31,26,23,.12);box-shadow:none}
.btn--ghost:hover{background:rgba(255,255,255,.9)}
.btn--sm{min-height:46px;padding:0 18px;font-size:.92rem}
.btn--xl{min-height:60px;padding:0 28px}

.hero{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;
  padding:120px 0 42px;
}
.hero-bg,.hero-bg__slide,.hero-bg__img-el,.hero-bg__overlay{position:absolute;inset:0}
.hero-bg__slide{opacity:0;transition:opacity 1.2s ease}.hero-bg__slide.active{opacity:1}
.hero-bg__img-el{width:100%;height:100%;object-fit:cover;transform:scale(1.02);filter:saturate(.92) contrast(.96) brightness(.72)}
.hero-bg__overlay{
  background:
    linear-gradient(180deg,rgba(22,17,14,.18) 0%,rgba(22,17,14,.48) 42%,rgba(22,17,14,.84) 100%),
    linear-gradient(110deg,rgba(0,0,0,.18) 10%,transparent 45%),
    radial-gradient(circle at 75% 30%, rgba(182,106,44,.20), transparent 28%);
}
.hero__inner{position:relative;z-index:2;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(320px,.8fr);gap:28px;align-items:end}
.hero__inner > *:not(.hero__badges){grid-column:1}
.hero__badges{grid-column:2;align-self:end}
.hero__eyebrow{display:inline-flex;align-items:center;gap:14px;padding:12px 18px;border:1px solid rgba(255,255,255,.14);background:rgba(255,253,250,.08);backdrop-filter:blur(14px);border-radius:999px;color:#fff;max-width:max-content}
.hero__eyebrow-line{width:42px;height:1px;background:linear-gradient(90deg,rgba(255,255,255,.2),rgba(255,255,255,.95))}
.hero__eyebrow-text{font-size:.88rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}
.hero h1{
  margin:22px 0 0;color:#fff;font-family:"Playfair Display",Georgia,serif;font-weight:700;
  font-size:clamp(3rem,7vw,6.25rem);line-height:.95;letter-spacing:-.03em;max-width:11ch
}
.hero h1 em,.section__title em,.accent{font-style:italic;color:#f0c58f;font-weight:600}
.hero__lead{
  margin:22px 0 0;max-width:58ch;color:rgba(255,251,246,.86);font-size:1.12rem
}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.hero__badges{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:18px;border-radius:30px;
  background:rgba(255,250,245,.10);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.12)
}
.hero-badge{
  min-height:118px;padding:18px;border-radius:22px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);
  color:#fff;display:flex;flex-direction:column;justify-content:space-between
}
.hero-badge__icon{font-size:1.5rem}
.hero-badge__label{font-weight:700;font-size:1rem;line-height:1.2}
.hero-scroll{position:absolute;right:26px;bottom:20px;display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.7);writing-mode:vertical-rl;text-orientation:mixed;z-index:2}
.hero-scroll__line{width:1px;height:88px;background:linear-gradient(180deg,transparent,rgba(255,255,255,.9),transparent)}
.hero-scroll__label{font-size:.82rem;letter-spacing:.18em;text-transform:uppercase}

.section{position:relative;padding:108px 0}
.section__label{
  display:inline-flex;align-items:center;gap:10px;margin-bottom:18px;padding:10px 16px;border-radius:999px;
  background:rgba(182,106,44,.10);color:var(--brand-2);font-size:.82rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase
}
.section__title{
  margin:0;max-width:11ch;font-family:"Playfair Display",Georgia,serif;font-size:clamp(2.3rem,4vw,4.4rem);line-height:.98;letter-spacing:-.03em
}
.section__subtitle{margin:20px 0 0;max-width:62ch;color:var(--muted);font-size:1.08rem}
.section--dark{background:linear-gradient(180deg,#1c1714 0%,#15110f 100%);color:#fff}
.section--dark .section__label{background:rgba(255,255,255,.08);color:#f7ceb0}
.section--dark .section__subtitle,.section--dark .location-info__note,.section--dark .location-contact-list a{color:rgba(255,249,242,.76)}
.section--warm{background:transparent}
.section--ink{background:linear-gradient(180deg,#efe7dc 0%,#e9e0d2 100%)}

.features-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-top:42px}
.feature-item{
  position:relative;padding:28px;border-radius:28px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
  min-height:240px;overflow:hidden
}
.feature-item::before{content:"";position:absolute;inset:auto -20% -30% auto;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,rgba(240,197,143,.16),transparent 70%)}
.feature-item__icon{display:grid;place-items:center;width:62px;height:62px;border-radius:20px;background:rgba(255,255,255,.08);font-size:1.5rem;margin-bottom:20px}
.feature-item__title{font-size:1.15rem;font-weight:800;letter-spacing:-.02em;margin-bottom:12px}
.feature-item__desc{margin:0;color:rgba(255,249,242,.78)}

.unit-grid{display:grid;grid-template-columns:1fr;gap:28px;margin-top:46px}
.unit-card{
  display:grid;grid-template-columns:minmax(360px,.95fr) minmax(0,1.05fr);gap:0;background:rgba(255,253,249,.9);
  border:1px solid var(--line);box-shadow:var(--shadow-lg);border-radius:34px;overflow:hidden
}
.unit-card:nth-child(even){grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr)}
.unit-card:nth-child(even) .unit-card__media{order:2}
.unit-card__media{position:relative;min-height:430px}
.unit-card__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.unit-card__media::after{content:"";position:absolute;inset:auto 0 0 0;height:45%;background:linear-gradient(180deg,transparent,rgba(0,0,0,.34))}
.unit-card__body{padding:36px 34px 34px;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(180deg,rgba(255,253,249,.98),rgba(246,239,230,.96))}
.unit-card__title{margin:0;font-family:"Playfair Display",Georgia,serif;font-size:clamp(2rem,3vw,3rem);line-height:1}
.unit-card__subtitle{margin:18px 0 0;color:var(--muted);font-size:1.02rem;max-width:55ch}
.unit-card__chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.unit-chip{padding:10px 14px;border-radius:999px;background:#fff;border:1px solid var(--line);font-size:.9rem;font-weight:700;color:var(--brand-2)}
.unit-card__thumbs{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:28px}
.unit-card__thumb{aspect-ratio:1/.8;border-radius:20px;overflow:hidden;box-shadow:0 10px 24px rgba(0,0,0,.08)}
.unit-card__thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.unit-card__thumb:hover img{transform:scale(1.06)}
.unit-card__actions{margin-top:28px}

.gallery-mosaic{display:grid;grid-template-columns:repeat(12,1fr);gap:16px;margin-top:44px}
.gallery-mosaic__item{grid-column:span 4;border-radius:28px;overflow:hidden;position:relative;box-shadow:var(--shadow)}
.gallery-mosaic__item:nth-child(5n+1){grid-column:span 7}.gallery-mosaic__item:nth-child(5n+2){grid-column:span 5}
.gallery-mosaic__item img{width:100%;height:100%;min-height:280px;object-fit:cover;transition:transform .7s ease, filter .3s ease}
.gallery-mosaic__item:hover img{transform:scale(1.05);filter:saturate(1.02)}
.lightbox{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(10,8,7,.84);z-index:200;padding:28px}
.lightbox.active{display:flex}.lightbox__img{max-width:min(1100px,100%);max-height:86vh;border-radius:26px}.lightbox__close{position:absolute;top:18px;right:18px;border:0;background:#fff;border-radius:999px;width:48px;height:48px;font-size:24px;cursor:pointer}

.location-grid{display:grid;grid-template-columns:minmax(0,.82fr) minmax(360px,1.18fr);gap:24px;margin-top:40px;align-items:stretch}
.location-info{
  padding:34px;border-radius:30px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);
  display:flex;flex-direction:column;justify-content:space-between
}
.location-info__address{font-family:"Playfair Display",Georgia,serif;font-size:clamp(1.7rem,2.4vw,2.4rem);line-height:1.1;max-width:14ch}
.location-contact-list{display:grid;gap:12px;margin:28px 0 22px}
.location-contact-list a{padding:13px 15px;border-radius:16px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08)}
.location-map{min-height:460px;border-radius:30px;overflow:hidden;box-shadow:var(--shadow-lg)}
.location-map iframe{width:100%;height:100%;border:0;filter:grayscale(.15) contrast(1.05) saturate(.9)}

.reviews-scroll{margin-top:42px;overflow:auto;padding-bottom:8px}.reviews-track{display:grid;grid-template-columns:repeat(3,minmax(280px,1fr));gap:18px}
.review-card{position:relative;padding:30px;border-radius:28px;background:rgba(255,253,249,.92);border:1px solid var(--line);box-shadow:var(--shadow);min-height:260px}
.review-card__decoration{position:absolute;top:18px;right:22px;font-family:"Playfair Display",Georgia,serif;font-size:72px;line-height:1;color:rgba(182,106,44,.16)}
.review-card__stars{letter-spacing:.18em;color:var(--brand);font-size:1rem;font-weight:800}
.review-card__text{margin:18px 0 0;color:var(--ink);font-size:1.02rem}.review-card__who{margin-top:18px;color:var(--muted);font-weight:700}

.booking-split{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);gap:22px;align-items:stretch;margin-top:42px}
.booking-info,.booking-template{
  padding:36px;border-radius:34px;background:rgba(255,253,249,.78);border:1px solid rgba(31,26,23,.1);box-shadow:var(--shadow)
}
.booking-info h2{margin:0;font-family:"Playfair Display",Georgia,serif;font-size:clamp(2rem,3vw,3.3rem);line-height:1}
.booking-info .lead{margin:18px 0 0;color:var(--muted);max-width:56ch}
.booking-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}
.booking-meta{margin-top:28px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.booking-meta-row{padding:18px;border-radius:20px;background:rgba(255,255,255,.55);border:1px solid var(--line);display:grid;gap:4px}
.booking-meta-row__k{font-size:.82rem;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.booking-meta-row__v{font-size:1.05rem;font-weight:800}
.booking-template{background:linear-gradient(180deg,#201914 0%,#16110e 100%);color:#fff}
.booking-template__title{font-size:1.15rem;font-weight:800;letter-spacing:.02em}.booking-template__sub,.tiny{color:rgba(255,250,244,.7)}
.copybox{margin:20px 0 16px;padding:20px;border-radius:20px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);color:#fff;white-space:pre-wrap;min-height:200px}

.page-shell{padding-top:0}
.page-hero{padding:136px 0 70px;background:linear-gradient(180deg,#1a1511 0%,#262019 100%);color:#fff;position:relative;overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:-10% auto auto -8%;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(182,106,44,.25),transparent 72%)}
.page-hero__inner{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:24px;align-items:end}
.page-title{margin:16px 0 0;font-family:"Playfair Display",Georgia,serif;font-size:clamp(2.4rem,4vw,4.6rem);line-height:.98;letter-spacing:-.03em;max-width:10ch}
.page-lead{margin:18px 0 0;color:rgba(255,249,242,.74);max-width:62ch}
.page-hero__actions{display:flex;flex-wrap:wrap;gap:14px;justify-content:flex-end}
.page-section{padding-top:34px}.page-stack{display:grid;gap:18px}
.page-card{padding:34px;border-radius:30px;background:rgba(255,253,249,.86);border:1px solid var(--line);box-shadow:var(--shadow)}
.page-card h2{margin:0 0 14px;font-family:"Playfair Display",Georgia,serif;font-size:2rem;line-height:1.04}.page-card p{margin:0 0 14px;color:var(--muted)}
.list-check{margin:10px 0 0;padding:0;list-style:none;display:grid;gap:12px}.list-check li{position:relative;padding-left:28px;color:var(--ink)}.list-check li::before{content:"✦";position:absolute;left:0;top:0;color:var(--brand)}

.footer{padding:80px 0 34px;background:#171310;color:#fff}.footer__grid{display:grid;grid-template-columns:1.15fr .85fr .85fr;gap:24px}
.footer__logo{display:block;height:72px;max-width:min(72vw,340px);width:auto;object-fit:contain;margin-bottom:16px;filter:drop-shadow(0 10px 24px rgba(0,0,0,.22))}
.footer__brand-text{font-family:"Playfair Display",Georgia,serif;font-size:1.8rem}.footer__tagline{max-width:34ch;color:rgba(255,250,244,.66)}
.footer__col-title{font-size:.88rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:#f0c58f;margin-bottom:16px}
.footer__links{display:grid;gap:12px}.footer__links a{color:rgba(255,250,244,.78)}.footer__links a:hover{color:#fff}
.footer__bottom{margin-top:28px;padding-top:18px;border-top:1px solid rgba(255,255,255,.08)}.footer__credit{display:flex;flex-wrap:wrap;gap:10px;color:rgba(255,250,244,.62)}
.footer__support{color:#f0c58f}

.floating-actions{position:fixed;right:18px;bottom:18px;display:grid;gap:10px;z-index:120}.fab{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;background:#fff;color:var(--ink);box-shadow:0 16px 32px rgba(0,0,0,.12);border:1px solid rgba(31,26,23,.08)}.fab svg{width:24px;height:24px;fill:currentColor}.fab--wa{background:#25D366;color:#fff}.fab--ig{background:linear-gradient(135deg,#ff8a5b,#d62976 60%,#4f5bd5);color:#fff}.fab--ph{background:var(--deep);color:#fff}

.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}.reveal.visible,.reveal.is-visible{opacity:1;transform:none}.reveal-d1{transition-delay:.08s}.reveal-d2{transition-delay:.16s}.reveal-d3{transition-delay:.24s}.reveal-d4{transition-delay:.32s}



.section--video-showcase{padding-top:40px}
.video-showcase{display:grid;grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);gap:34px;align-items:center;padding:34px;border:1px solid rgba(255,255,255,.08);border-radius:34px;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.02));box-shadow:0 28px 70px rgba(0,0,0,.28)}
.video-showcase__content .section__title{max-width:11ch}
.video-showcase__content .section__subtitle{max-width:58ch}
.video-showcase__actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.video-frame{position:relative;border-radius:28px;overflow:hidden;background:#000;border:1px solid rgba(255,255,255,.08);box-shadow:0 24px 60px rgba(0,0,0,.34);aspect-ratio:16 / 9;min-height:0}
.video-frame::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.04),transparent 26%,transparent 74%,rgba(0,0,0,.18));pointer-events:none;z-index:1}
.video-frame__media{display:block;width:100%;height:100%;object-fit:cover;background:#000}
.video-frame__media::-webkit-media-controls-panel{background:linear-gradient(180deg,transparent,rgba(0,0,0,.7))}

.video-frame__sound-hint{position:absolute;left:16px;top:16px;transform:none;z-index:4;display:inline-flex;align-items:center;justify-content:center;min-width:auto;padding:12px 16px;border:1px solid rgba(255,255,255,.24);border-radius:999px;background:rgba(8,8,8,.68);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);color:#fff;font-weight:800;letter-spacing:.10em;text-transform:uppercase;font-size:.76rem;line-height:1;box-shadow:0 14px 36px rgba(0,0,0,.32);cursor:pointer;transition:transform .22s ease,background .22s ease,opacity .22s ease}
.video-frame__sound-hint:hover{transform:scale(1.03);background:rgba(8,8,8,.82)}
.video-frame__sound-hint.is-hidden{opacity:0;pointer-events:none;transform:scale(.94)}
.video-frame__sound-hint-text{display:block;white-space:nowrap}

@media (max-width:1100px){
  .hero__inner{grid-template-columns:1fr}
  .hero__badges{grid-column:1;max-width:760px}
  .features-grid{grid-template-columns:repeat(2,1fr)}
  .unit-card,.unit-card:nth-child(even){grid-template-columns:1fr}.unit-card:nth-child(even) .unit-card__media{order:0}
  .gallery-mosaic__item,.gallery-mosaic__item:nth-child(5n+1),.gallery-mosaic__item:nth-child(5n+2){grid-column:span 6}
  .location-grid,.booking-split,.page-hero__inner,.footer__grid,.video-showcase{grid-template-columns:1fr}
  .page-hero__actions{justify-content:flex-start}
}
@media (max-width:780px){
  :root{--topbar-h:76px}
  .nav{display:none}.hamburger{display:flex}.mobile-nav{display:block}
  .brand{max-width:min(62vw,260px)}
  .brand__logo{height:58px!important;max-width:min(62vw,240px);padding:0;border-radius:0}
  .footer__logo{height:60px;max-width:min(70vw,250px)}
  .brand__text{display:none}
  .hero{min-height:auto;padding:108px 0 28px}.hero h1{max-width:12ch}.hero__lead{font-size:1rem}
  .hero__badges{grid-template-columns:1fr 1fr}.hero-badge{min-height:104px;padding:16px}
  .section{padding:82px 0}.section__title{max-width:100%}
  .features-grid{grid-template-columns:1fr}
  .unit-card__media{min-height:300px}.unit-card__body,.location-info,.booking-info,.booking-template,.page-card,.video-showcase{padding:24px}.video-showcase{gap:20px}.video-showcase__content .section__title{max-width:100%}.video-frame{aspect-ratio:16 / 10;min-height:0}
  .gallery-mosaic{grid-template-columns:1fr 1fr}.gallery-mosaic__item,.gallery-mosaic__item:nth-child(5n+1),.gallery-mosaic__item:nth-child(5n+2){grid-column:auto}
  .gallery-mosaic__item img{min-height:190px}
  .reviews-track{grid-template-columns:repeat(3,85vw)}
  .booking-meta{grid-template-columns:1fr}
  .btn,.btn--xl{width:100%}
  .topbar__right{margin-left:auto}.topbar__right .btn--sm{display:none}
}

@media (max-width:780px){
  .topbar{background:linear-gradient(180deg,rgba(17,13,11,.78),rgba(17,13,11,.52));border-bottom:1px solid rgba(255,255,255,.06);backdrop-filter:blur(14px) saturate(120%)}
  .topbar__inner{gap:12px}
  .brand{max-width:min(62vw,250px)}
  .brand__logo{filter:drop-shadow(0 10px 22px rgba(0,0,0,.52)) drop-shadow(0 0 10px rgba(0,0,0,.18))}
  .hamburger{display:flex!important;flex:0 0 48px}
}

@media (max-width:560px){
  body{background:linear-gradient(180deg,#f8f3ec 0%,#f3ecdf 100%)}
  .container{width:min(calc(100% - 20px),var(--container))}
  .hero__eyebrow{padding:10px 14px}.hero__eyebrow-text{font-size:.76rem}
  .hero h1{font-size:clamp(2.5rem,12vw,3.6rem)}
  .hero__badges{grid-template-columns:1fr}
  .hero-scroll{display:none}
  .location-map{min-height:320px}
  .page-title{max-width:12ch}
  .section--video-showcase{padding-top:20px}
  .video-showcase{padding:18px;border-radius:24px}
  .video-frame{border-radius:20px;aspect-ratio:16 / 11}.video-frame__sound-hint{min-width:116px;padding:12px 16px;font-size:.74rem;max-width:calc(100% - 28px)}
}


/* ══════════ SIZDEN GELENLER ══════════ */
.section--ugc{
  overflow:hidden;
}
.ugc-marquee{
  position:relative;
  margin-top:30px;
  mask-image:linear-gradient(to right, transparent, #000 7%, #000 93%, transparent);
  -webkit-mask-image:linear-gradient(to right, transparent, #000 7%, #000 93%, transparent);
}
.ugc-track{
  display:flex;
  align-items:stretch;
  gap:20px;
  width:max-content;
  animation:ugc-marquee 34s linear infinite;
  will-change:transform;
}
.ugc-marquee:hover .ugc-track{
  animation-play-state:paused;
}
.ugc-card{
  position:relative;
  width:clamp(220px, 24vw, 320px);
  aspect-ratio:3 / 4;
  border-radius:28px;
  overflow:hidden;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 18px 50px rgba(0,0,0,.28);
  flex:0 0 auto;
}
.ugc-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 52%, rgba(0,0,0,.22) 100%);
  pointer-events:none;
  z-index:1;
}
.ugc-card img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  transform:scale(1.001);
}
@keyframes ugc-marquee{
  from{ transform:translateX(0); }
  to{ transform:translateX(calc(-50% - 10px)); }
}
@media (max-width: 991px){
  .ugc-track{ gap:16px; animation-duration:30s; }
  .ugc-card{ width:clamp(200px, 42vw, 270px); border-radius:24px; }
}
@media (max-width: 640px){
  .ugc-marquee{
    margin-top:24px;
    mask-image:none;
    -webkit-mask-image:none;
  }
  .ugc-track{ gap:12px; animation-duration:26s; }
  .ugc-card{ width:72vw; max-width:280px; border-radius:22px; }
}

@media (max-width: 640px){.video-frame__sound-hint{left:12px;top:12px;padding:10px 13px;font-size:.7rem;letter-spacing:.08em}}
