:root{
  --blue:#0e2b45;
  --blue-2:#143a5d;
  --gold:#d4af63;
  --cream:#f6f1e8;
  --ivory:#fffcf7;
  --text:#233242;
  --muted:#627180;
  --line:#e6d7be;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Georgia,"Times New Roman",serif;
  color:var(--text);
  background:var(--cream);
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
.container{width:min(1200px,calc(100% - 32px));margin:0 auto}

.nav-wrap{position:fixed;top:14px;left:0;right:0;z-index:20}
.nav{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px 18px;border-radius:999px;
  background:rgba(8,25,42,.72);
  backdrop-filter:blur(12px);
  border:1px solid rgba(212,175,99,.28);
  box-shadow:0 14px 40px rgba(0,0,0,.18);
}
.brand{
  display:flex;flex-direction:column;gap:2px
}
.brand-title{
  color:#f4e3b2;font-size:34px;letter-spacing:.02em;font-weight:400;line-height:1;
  font-family:'Brush Script MT','Snell Roundhand','Apple Chancery','URW Chancery L',cursive;
  font-style:italic;text-shadow:0 2px 10px rgba(0,0,0,.18)
}
.brand-sub{
  margin-left:6px;color:rgba(244,227,178,.82);font-size:9px;letter-spacing:.38em;
  font-family:Arial,Helvetica,sans-serif;text-transform:uppercase
}
.nav .menu{
  display:flex;flex-wrap:wrap;justify-content:center;gap:22px;
  color:#f2e0ad;letter-spacing:.18em;font-size:12px;font-family:Arial,Helvetica,sans-serif
}
.cta{
  border:1px solid var(--gold);color:#f5df9f;padding:10px 16px;border-radius:999px;
  letter-spacing:.16em;font-size:12px;font-weight:bold;white-space:nowrap;
  font-family:Arial,Helvetica,sans-serif
}

.hero{min-height:100svh;position:relative;overflow:hidden;color:white}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(248,244,236,.18), rgba(10,24,38,.18) 30%, rgba(7,20,34,.42)),
    radial-gradient(circle at top, rgba(255,245,220,.34), transparent 30%);
	width:100%; height: 100%; z-index: 1;
}
.hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-content{position:relative;min-height:100svh;display:flex;align-items:end;padding:140px 0 84px; z-index:10;}
.eyebrow{
  text-transform:uppercase;letter-spacing:.42em;font-size:12px;color:#fff2c9;
  margin-bottom:18px;font-family:Arial,Helvetica,sans-serif
}
h1{
  margin:0;font-size:clamp(46px,8vw,110px);line-height:.94;font-weight:400;
  text-shadow:0 4px 18px rgba(8,18,28,.22)
}
.gold{color:#f0d38a}
.hero p{
  max-width:720px;font-size:18px;line-height:1.9;color:rgba(255,255,255,.96);
  margin:22px 0 0;font-family:Arial,Helvetica,sans-serif
}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:28px}
.btn{
  display:inline-block;padding:14px 22px;border-radius:999px;letter-spacing:.14em;font-size:12px;
  font-weight:700;font-family:Arial,Helvetica,sans-serif;text-align:center
}
.btn-gold{background:var(--gold);color:#0b2236}
.btn-light{border:1px solid rgba(255,255,255,.5);color:white}
.btn-outline-dark{border:1px solid var(--blue);color:var(--blue)}

.card-overlap{position:relative;margin-top:-24px;z-index:2}
.card{
  background:rgba(255,252,246,.92);border:1px solid var(--line);border-radius:32px;
  box-shadow:0 25px 70px rgba(10,20,30,.10);backdrop-filter:blur(8px)
}
.intro{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;padding:28px}
.section-tag{
  color:#b08a43;text-transform:uppercase;letter-spacing:.3em;font-size:12px;
  font-family:Arial,Helvetica,sans-serif
}
h2{font-size:clamp(30px,5vw,60px);line-height:1.08;font-weight:400;margin:16px 0 0;color:var(--blue)}
.intro p,.section-copy{
  color:#596978;line-height:1.9;font-size:17px;font-family:Arial,Helvetica,sans-serif
}
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:28px}
.features.four{grid-template-columns:repeat(4,1fr)}
.feature{
  background:white;border:1px solid #eee2cf;border-radius:22px;padding:22px;
  box-shadow:0 4px 18px rgba(0,0,0,.04);min-width:0
}
.bar{width:46px;height:4px;border-radius:999px;background:var(--gold)}
.feature p{margin:14px 0 0;font-size:14px;line-height:1.8;color:#435462;font-family:Arial,Helvetica,sans-serif}
.round-image{
  overflow:hidden;border-radius:28px;border:1px solid #e9dcc8;
  box-shadow:0 18px 50px rgba(15,28,40,.08);min-height:420px
}
.round-image img{width:100%;height:100%;object-fit:cover}

section.block{padding:88px 0}
.section-head{display:flex;justify-content:space-between;gap:20px;align-items:end;margin-bottom:34px}
.section-head .text{max-width:620px}
.gallery{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.gallery.three{grid-template-columns:repeat(3,1fr)}
.gallery article{
  background:white;border:1px solid #e8dcc8;border-radius:32px;overflow:hidden;
  box-shadow:0 18px 50px rgba(15,28,40,.06);min-width:0
}
.gallery .media{height:340px;overflow:hidden}
.gallery .media img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.gallery article:hover .media img{transform:scale(1.03)}
.gallery .copy{padding:26px}
.gallery h3{margin:0;font-size:34px;color:var(--blue);font-weight:400}
.gallery p{margin:12px 0 0;color:#667481;font-family:Arial,Helvetica,sans-serif;line-height:1.8}

.booking{display:grid;grid-template-columns:.95fr 1.05fr;gap:26px}
.booking .left{
  overflow:hidden;border-radius:32px;border:1px solid #e7dac6;background:white;
  box-shadow:0 18px 50px rgba(15,28,40,.06);min-height:560px
}
.booking .left img{width:100%;height:100%;object-fit:cover}
.booking .right{
  border-radius:32px;border:1px solid #dbc69e;background:linear-gradient(180deg,#0d2840 0%,#163a59 100%);
  color:white;padding:38px;box-shadow:0 18px 50px rgba(10,20,30,.18)
}
.booking .right h2{color:white}
.booking .right p{color:rgba(255,255,255,.82);font-family:Arial,Helvetica,sans-serif;line-height:1.9}
.info{
  border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.06);
  border-radius:20px;padding:18px 20px;margin-top:14px;backdrop-filter:blur(8px);
  font-family:Arial,Helvetica,sans-serif
}
.info small{
  display:block;text-transform:uppercase;letter-spacing:.22em;color:#f0d998;
  font-size:11px;margin-bottom:8px
}
footer{border-top:1px solid #d9c9aa;background:#0a2236;color:white;padding:34px 0}
footer .container{display:flex;justify-content:space-between;align-items:center;gap:20px}
.footer-meta{display:flex;flex-direction:column;gap:8px;align-items:flex-end;font-family:Arial,Helvetica,sans-serif}
.footer-line{font-size:14px;letter-spacing:.12em;color:rgba(255,255,255,.78)}
.footer-powered{font-size:12px;letter-spacing:.08em;color:rgba(255,255,255,.58)}
.footer-powered a{color:#f0d998}

@media (max-width:1100px){
  .intro,.booking{grid-template-columns:1fr}
  .features.four{grid-template-columns:repeat(2,1fr)}
  .gallery.three{grid-template-columns:repeat(2,1fr)}
  .booking .left{min-height:440px}
		.hero-content{top:-50px !important}
}
@media (max-width:900px){
		.hero-content{top:-50px !important}
  .container{width:min(100% - 24px,1200px)}
  .nav{border-radius:28px;align-items:flex-start}
  .nav .menu{display:none}
  .intro,.booking,.gallery,.features,.features.four{grid-template-columns:1fr}
  .gallery.three{grid-template-columns:1fr}
  .section-head{flex-direction:column;align-items:start}
  .gallery .media{height:280px}
  .booking .right,.card,.gallery article{border-radius:26px}
  footer .container{flex-direction:column;align-items:flex-start}
  .footer-meta{align-items:flex-start}
  .hero-content{padding:128px 0 64px}
  .hero p{font-size:16px;line-height:1.8}
}
@media (max-width:640px){
	.hero-content{top:-50px !important}
  .nav-wrap{top:10px}
  .nav{padding:12px 14px;gap:10px}
  .brand-title{font-size:30px}
  .cta{padding:9px 12px;font-size:11px;letter-spacing:.12em}
  .hero-content{align-items:end;padding:112px 0 42px}
  .eyebrow{font-size:10px;letter-spacing:.28em;margin-bottom:14px}
  h1{font-size:clamp(38px,13vw,56px);line-height:.96}
  .hero p{font-size:15px;line-height:1.75;max-width:100%}
  .hero-actions{gap:10px;flex-direction:column;align-items:stretch}
  .btn{width:100%;padding:14px 18px;font-size:11px;letter-spacing:.12em}
  section.block{padding:64px 0}
  .intro{padding:18px;gap:20px}
  .card{border-radius:24px}
  .round-image{min-height:300px;border-radius:22px}
  h2{font-size:clamp(26px,9vw,40px);line-height:1.12}
  .section-tag{font-size:10px;letter-spacing:.22em}
  .intro p,.section-copy,.gallery p,.booking .right p{font-size:15px;line-height:1.75}
  .features,.features.four,.gallery,.gallery.three{grid-template-columns:1fr !important;gap:16px}
  .feature{padding:18px;border-radius:18px}
  .gallery article{border-radius:24px}
  .gallery .media{height:240px}
  .gallery .copy{padding:18px}
  .gallery h3{font-size:28px !important}
  .booking{grid-template-columns:1fr;gap:16px}
  .booking .left{min-height:280px;border-radius:24px}
  .booking .right{padding:22px 18px;border-radius:24px}
  .info{padding:16px;border-radius:16px}
  footer{padding:26px 0}
  footer .container{gap:12px}
  .footer-line{font-size:12px;letter-spacing:.08em}
}
@media (min-width:1280px){ 	.hero-content{top:-250px !important}}