*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Times New Roman',sans-serif;color:#f6f1f1;overflow-x:hidden;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}
ul{list-style:none;}

/* ══════════ TOPBAR ══════════ */
#topbar{
  background:#C48037;
  color:#fff;
  padding:10.5px 50px;
  display:flex;align-items:center;justify-content:space-between;
  font-size:13.5px;
}
.tb-contacts{display:flex;gap:30px;align-items:center;}
.tb-contacts span{display:flex;align-items:center;gap:8px;}
.tb-contacts i{font-size:13px;}
.tb-book{
  background:#fff;color:#3b3834;
  padding:8px 28px;border-radius:3px;
  font-weight:700;font-size:13px;
  border:2px solid #fff;
  transition:all .2s;
}
.tb-book:hover{background:transparent;color:#fff;}

/* ══════════ HEADER ══════════ */
#header{
  background:#fff;
  padding:0 50px;
  height:88px;
  display:flex;align-items:center;justify-content:space-between;
  box-shadow:0 2px 10px rgba(0,0,0,.08);
  position:sticky;top:0;z-index:9999;
}
.logo img{height:74px;width:auto;object-fit:contain;}
.logo-text-fallback{
  display:none;flex-direction:column;
}
.logo-text-fallback strong{font-family:'EB Garamond',serif;font-size:20px;color:#c8831a;}
.logo-text-fallback span{font-size:10px;color:#999;letter-spacing:2px;text-transform:uppercase;}

nav > ul{display:flex;align-items:center;}
nav > ul > li{position:relative;}
nav > ul > li > a{
  font-family: "DM Sans", Sans-serif;
  display:block;padding:0 8px;
  height:88px;line-height:88px;
  font-size:12px;font-weight:400;
  color:#000000;white-space:nowrap;
  transition:color .2s;
}
nav > ul > li > a:hover{color:#c8831a;}
nav > ul > li:hover > .sub{display:block;}
.sub{
  display:none;
  position:absolute;top:100%;left:0;
  background:#fff;min-width:185px;
  box-shadow:0 6px 20px rgba(0,0,0,.1);
  border-top:3px solid #c8831a;
  z-index:9999;
}
.sub li a{
  display:block;padding:11px 16px;
  font-size:13px;color:#444;
  border-bottom:1px solid #f5f5f5;
  transition:background .15s,color .15s;
}
.sub li a:hover{background:#fff8f0;color:#c8831a;}

.hdr-right{display:flex;align-items:center;gap:8px;}
.social-icon{
  width:34px;height:34px;border-radius:5px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:15px;transition:opacity .2s;
}
.social-icon:hover{opacity:.8;}
.si-fb{background:#1877f2;}
.si-ig{background:linear-gradient(45deg,#f09433 0%,#e6683c 25%,#dc2743 50%,#cc2366 75%,#bc1888 100%);}
.hamburger{display:none;font-size:22px;cursor:pointer;color:#c8831a;margin-left:10px;}

/* ══════════ HERO ══════════ */
#hero{
  position:relative;
  min-height:calc(125vh - 88px);
  overflow:visible;
}
.hslide{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  opacity:0;transition:opacity 1.4s ease;
}
.hslide.on{opacity:1;}
.hslide::after{
  content:'';position:absolute;inset:0;
  background:rgba(0,0,0,.38);
}
.hslide:nth-child(1){background-image:url('https://reefviewstaycations.com/wp-content/uploads/2025/12/Reef-View-Pavilions_pk29365_1-1.gif');}
.hslide:nth-child(2){background-image:url('https://reefviewstaycations.com/wp-content/uploads/2026/01/WhatsApp-Image-2026-01-05-at-7.59.02-PM-3-1024x682.jpeg');}
.hslide:nth-child(3){background-image:url('https://reefviewstaycations.com/wp-content/uploads/2026/01/WhatsApp-Image-2026-01-05-at-7.59.00-PM-1-1024x683.jpeg');}
.hslide:nth-child(4){background-image:url('https://reefviewstaycations.com/wp-content/uploads/2025/12/wheres-grenada-caribbean-island-guide.avif');}

.hero-body{
  position:relative;z-index:2;
  display:flex;flex-direction:column;
  justify-content:flex-end;
  min-height:calc(100vh - 88px);
  padding:0 60px 90px;
  max-width:800px;
}
.hero-body h1{
  font-family:'Times New Roman',serif;
  font-size:40px;font-weight:500;
  color:#fff;line-height:1.18;
  margin-bottom:18px;
  transition:opacity .8s,transform .8s;
}
.hero-body p{
  font-size:17px;color:rgba(255,255,255,.9);
  line-height:1.8;margin-bottom:30px;max-width:520px;
}
.hero-btns{display:flex;gap:14px;flex-wrap:wrap;}
.btn-pill{
  padding:13px 30px;border-radius:30px;
  font-size:17px;font-weight:400;
  background:#c8831a;color:#fff;
  border:2px solid #c8831a;
  transition:all .2s;cursor:pointer;
}
.btn-pill:hover{background:#b07015;border-color:#b07015;transform:translateY(-2px);}
.btn-pill-outline{
  padding:11px 28px;border-radius:30px;
  font-size:17px;font-weight:400;
  background:#c8831a;color:#fff;
  border:2px solid #c8831a;
  transition:all .2s;cursor:pointer;
}
.btn-pill-outline:hover{background:#c8831a;transform:translateY(-2px);}

.btn-contact {
  display:inline-block;
  background:#c8831a;
  color:#fff;
  padding:12px 30px;
  border-radius:4px;
  font-size:13px;
  font-weight:600;
  margin-top:8px;
  transition:background .2s;
  margin-right:340px;
}

/* ══════════ DEALS ══════════ */
#deals{
  background:#c1624a;
  margin-top:-74px;
  position:relative;z-index:3;
  border-radius:16px 16px 15px 15px;
  padding:10px 60px 36px;
  margin-left:80px;
  margin-right:80px;
}
.deals-flex{
  max-width:1200px;margin:0 auto;
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:30px;
  align-items:center;
}
.deals-text h2{
  font-family:'EB Garamond',serif;
  font-size:34px;color:#fff;font-weight:700;
  margin-bottom:14px;
}
.deals-text p{font-size:14px;color:rgba(255,255,255,.9);line-height:1.8;margin-bottom:22px;}

.deals-diamonds{
  display:flex;gap:115px;justify-content:center;align-items:center;
  flex-wrap:wrap;
  margin-top:25px;
}
.diamond{
  width:190px;height:125px;
  transform:rotate(45deg);
  /* overflow:hidden; */
  border-radius:10px;
  box-shadow:0 6px 22px rgba(0,0,0,.28);
  flex-shrink:0;
}
.diamond img{
  width:145%;height:145%;
  object-fit:cover;
  transform:rotate(-45deg) translate(-20%,-0%);
  display:block;
}

/* ══════════ ABOUT ══════════ */
#about{
  background:#fff;
  padding:35px 60px;
}
.about-wrap{
  max-width:1200px;
  display:grid;
  grid-template-columns:480px 1fr;
  gap:160px;
  align-items:start;
  margin-right:-58px;
}
.about-imgs{
  position:relative;
  height:480px;
}
.about-img-main{
  position:absolute;
  left:-30px;top:0;
  width:360px;height:430px;
  object-fit:cover;
  border-radius:6px;
}
.about-img-inset{
  position:absolute;
  left:357px;top:80px;
  width:260px;height:260px;
  object-fit:cover;
  border-radius:6px;
  border:5px solid #fff;
  box-shadow:0 8px 26px rgba(0,0,0,.18);
}
.about-text .eyebrow{
  font-size:13px;font-weight:700;
  color:#c8831a;letter-spacing:2px;
  text-transform:uppercase;margin-bottom:12px;
  display:block;
}
.about-text h2{
  font-family:'EB Garamond',serif;
  font-size:38px;font-weight:700;color:#1a1a1a;
  line-height:1.25;margin-bottom:16px;
}
.about-divider{width:70px;height:2px;background:#c8831a;margin-bottom:22px;}
.about-text p{font-size:15px;color:#555;line-height:1.9;margin-bottom:18px;}

/* ══════════ SPECIALISED ══════════ */

.gallery-sec-title{
  text-align:center;
  margin-bottom:44px;
}
.photos-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.photos-grid img{
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
  border-radius:8px;
  transition:transform .4s,box-shadow .4s;
}
.photos-grid img:hover{transform:scale(1.02);box-shadow:0 10px 30px rgba(0,0,0,.15);}

/* ══════════ WHY CHOOSE ══════════ */
#why{position:relative;background:#fff;}

.why-wrap{
  max-width:100%;
  display:grid;
  grid-template-columns:1fr 1fr;
  position:relative;
}
.why-text{
  padding:70px 80px 70px 80px;
  background:#fff;
  display:flex;flex-direction:column;justify-content:center;
}
.why-text h2{
  font-family:'EB Garamond',serif;
  font-size:38px;font-weight:700;color:#1a1a1a;
  margin-bottom:16px;
}
.why-divider{width:70px;height:2px;background:#c8831a;margin-bottom:24px;}
.why-text p{font-size:15px;color:#555;line-height:1.9;margin-bottom:18px;}

.why-img-col{
  position:relative;
  overflow:visible;
}
.why-img-col img{
  position:absolute;
  top:-130px;
  left:0;right:0;
  width:100%;
  height:calc(100% + 80px);
  object-fit:cover;
  object-position:center top;
  display:block;
}

/* ══════════ COUNTERS ══════════ */
#counters{
  background:#fff;
  padding:15px 60px;
  border-top:1px solid #f0e8e0;
  margin-left:593px;
  margin-top:-55px;
}
.cnt-row{
  max-width:700px;margin:0 auto;
  display:flex;gap:24px;justify-content:center;
}
.cnt-box{
  background:#ffffff;color:#000000;
  border-radius:10px;padding:30px 44px;
  text-align:center;flex:1;
}
.cnt-box .num{
  font-family:'EB Garamond',serif;
  font-size:54px;font-weight:700;line-height:1;
}
.cnt-box .plus{font-size:30px;font-weight:700;vertical-align:top;margin-top:8px;display:inline-block;}
.cnt-box .lbl{font-size:19px;margin-top:6px;opacity:.9;}

/* ══════════ GRENADA ══════════ */
#grenada{
  background:#2c4bce;
  padding:80px 60px;
}
.gren-wrap{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:70px;align-items:start;
}
.gren-left h2{
  font-family:'EB Garamond',serif;
  font-size:36px;font-weight:700;color:#fff;
  line-height:1.25;margin-bottom:14px;
}
.gren-bar{width:60px;height:2px;background:#c8831a;margin-bottom:20px;}
.gren-left p{font-size:14.5px;color:rgba(255,255,255,.85);line-height:1.85;margin-bottom:28px;}
.gren-left img{
  width:100%;height:320px;object-fit:cover;
  border-radius:10px;
}
.gren-list{display:flex;flex-direction:column;}
.gren-row{
  display:flex;align-items:center;gap:20px;
  padding:15px 0;
  border-bottom:1px solid rgba(255,255,255,.22);
  cursor:pointer;transition:opacity .2s;
}
.gren-row:last-child{border-bottom:none;}
.gren-row:hover{opacity:.8;}
.gren-thumb{
  width:76px;height:76px;border-radius:50%;
  overflow:hidden;flex-shrink:0;
  border:3px solid rgba(255,255,255,.3);
}
.gren-thumb img{width:100%;height:100%;object-fit:cover;}
.gren-name{
  font-family:'EB Garamond',serif;
  font-size:26px;color:#fff;font-weight:600;
}

/* ══════════ CONTACT ══════════ */

.contact-wrap{
  position:relative;z-index:2;
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;
  gap:40px;padding:80px 60px;
  align-items:stretch;
}
.map-col{
  border-radius:10px;overflow:hidden;
  box-shadow:0 6px 24px rgba(0,0,0,.3);
  display:flex;flex-direction:column;
}
.map-col iframe{
  width:100%;
  flex:1;
  min-height:480px;
  border:none;display:block;
}
.form-col{
  background:#c8831a;
  border-radius:10px;padding:34px 28px;
  display:flex;flex-direction:column;
}
.cf-label{display:block;font-size:13.5px;font-weight:700;color:#fff;margin-bottom:6px;}
.cf-label .req{color:#fff;font-size:11px;}
.cf-inp,.cf-area{
  width:100%;padding:12px 14px;
  border:none;border-radius:5px;
  font-size:14px;font-family:'Open Sans',sans-serif;
  outline:none;color:#333;background:#fff;
  margin-bottom:14px;
}
.cf-area{height:130px;resize:vertical;margin-bottom:14px;}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.cf-row .cf-inp{margin-bottom:0;}
.cf-row-wrap{margin-bottom:14px;}
.cf-submit{
  background:#c8831a;color:#fff;
  border:2px solid #fff;
  padding:13px 34px;
  border-radius:30px;
  font-size:14px;font-weight:700;
  cursor:pointer;font-family:'Open Sans',sans-serif;
  transition:all .2s;
  margin-top:4px;
  align-self:flex-start;
}
.cf-submit:hover{background:#fff;color:#c8831a;}

/* ══════════ FOOTER ══════════ */
#footer{background:#ffffff;color:rgba(255,255,255,.8);padding:65px 60px 0;}
.ft-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1.2fr 1.4fr;
  gap:40px;padding-bottom:50px;
}
.ft-logo img{height:68px;margin-bottom:14px;}
.ft-logo-name{font-family:'EB Garamond',serif;font-size:21px;color:#000000;font-weight:700;margin-bottom:12px;}
.ft-brand-desc{font-size:17px;line-height:1.85;color:#000000;}
.ft-socials{display:flex;gap:10px;margin-top:18px;}
.ft-socials a{
  width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  color:#000000;font-size:14px;transition:background .2s;
}
.ft-socials a:hover{background:#c8831a;}
.ft-col h4{font-family:'EB Garamond',serif;font-size:22px;color:#000000;font-weight:700;margin-bottom:18px;}
.ft-col ul li{margin-bottom:10px;}
.ft-col ul li a{
  font-size:17px;color:#000000;
  display:flex;align-items:center;gap:7px;transition:color .2s;
}
.ft-col ul li a:hover{color:#c8831a;}
.ft-col ul li a i{color:#c8831a;font-size:10px;}
.ft-ci{display:flex;gap:10px;align-items:flex-start;margin-bottom:13px;font-size:17px;color:#000000;line-height:1.6;}
.ft-ci i{color:#c8831a;flex-shrink:0;margin-top:3px;font-size:14px;}
.nl-form{display:flex;margin-top:14px;}
.nl-form input{flex:1;padding:11px 13px;border:none;border-radius:4px 0 0 4px;font-size:13px;outline:none;font-family:'Open Sans',sans-serif;}
.nl-form button{background:#c8831a;color:#fff;border:none;padding:11px 18px;border-radius:0 4px 4px 0;font-weight:700;font-size:13px;cursor:pointer;transition:background .2s;}
.nl-form button:hover{background:#b07015;}
.ft-bottom{
  background:#2a2c2d;
  border-top:1px solid rgba(255,255,255,.1);
  max-width:1265px;margin:0 auto;
  padding:20px 119px;
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:10px;
  font-size:17px;color:rgba(255,255,255,.4);
}
.ft-bottom a{color:#c8831a;}

/* ══════════ WHATSAPP ══════════ */
.wa{
  position:fixed;bottom:26px;right:26px;
  background:#25d366;color:#fff;
  width:56px;height:56px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:28px;
  box-shadow:0 4px 18px rgba(0,0,0,.22);
  z-index:99999;transition:transform .2s;
}
.wa:hover{transform:scale(1.1);}

/* ══════════ MOB NAV ══════════ */
#mobnav{
  display:none;position:fixed;inset:0;
  background:#fff;z-index:99998;
  flex-direction:column;padding:80px 30px;overflow-y:auto;
}
#mobnav.open{display:flex;}
.mob-close{position:absolute;top:20px;right:24px;font-size:26px;cursor:pointer;color:#c8831a;}
#mobnav ul li{border-bottom:1px solid #f0f0f0;}
#mobnav ul li a{display:block;padding:13px 0;font-size:16px;font-weight:600;color:#333;}
#mobnav ul li a:hover{color:#c8831a;}

/* ══════════════════════════════════════
   RESPONSIVE — TABLET (max 1050px)
═══════════════════════════════════════ */
@media(max-width:1050px){
  /* Deals */
  #deals{margin-left:30px;margin-right:30px;}
  .deals-diamonds{gap:40px;}

  /* About */
  .about-wrap{
    grid-template-columns:1fr 1fr;
    gap:40px;
    margin-right:0;
  }
  .about-imgs{height:360px;}
  .about-img-main{width:280px;height:340px;left:0;}
  .about-img-inset{left:auto;right:-10px;width:200px;height:200px;top:100px;}

  /* Why */
  .why-img-col img{top:-80px;height:calc(100% + 50px);}

  /* Counters */
  #counters{margin-left:0;margin-top:0;padding:40px 60px;}

  /* Footer */
  .ft-grid{grid-template-columns:1fr 1fr;}
  .ft-bottom{padding:20px 40px;}
}

/* ══════════════════════════════════════
   RESPONSIVE — MOBILE (max 860px)
═══════════════════════════════════════ */
@media(max-width:860px){

  /* Topbar */
  #topbar{padding:10px 18px;font-size:11.5px;flex-wrap:wrap;gap:8px;}
  .tb-contacts{gap:14px;flex-wrap:wrap;}

  /* Header */
  nav{display:none;}
  .hamburger{display:block;}
  #header{padding:0 18px;}

  /* Hero */
  #hero{min-height:90vh;}
  .hero-body{
    padding:0 24px 70px;
    min-height:80vh;
    max-width:100%;
  }
  .hero-body h1{font-size:30px;}
  .hero-body p{font-size:15px;}

  /* Deals */
  #deals{
    margin-left:16px;margin-right:16px;
    margin-top:-40px;
    padding:24px 20px 30px;
    border-radius:12px;
  }
  .deals-flex{grid-template-columns:1fr;}
  .deals-diamonds{gap:30px;margin-top:20px;}
  .diamond{width:130px;height:130px;}

  /* About */
  #about{padding:50px 24px;}
  .about-wrap{
    grid-template-columns:1fr;
    gap:0;
    margin-right:0;
  }
  .about-imgs{
    height:320px;
    margin-bottom:30px;
  }
  .about-img-main{
    position:relative;
    left:0;top:0;
    width:100%;height:300px;
  }
  .about-img-inset{
    position:absolute;
    left:auto;right:10px;
    top:auto;bottom:-40px;
    width:150px;height:150px;
    border:4px solid #fff;
  }

  /* Gallery */
  #gallery-sec{padding:60px 16px;}
  .photos-grid{grid-template-columns:repeat(2,1fr);gap:10px;}

  /* Why */
  #why{}
  .why-wrap{grid-template-columns:1fr;}
  .why-text{padding:50px 24px;}
  .why-text .btn-contact{margin-right:0;}
  .why-img-col{overflow:hidden;min-height:280px;}
  .why-img-col img{
    position:relative;
    top:0;
    height:280px;
    width:100%;
  }

  /* Counters */
  #counters{
    margin-left:0;margin-right:0;
    margin-top:0;
    padding:40px 24px;
    border-top:1px solid #f0e8e0;
  }
  .cnt-row{gap:16px;}
  .cnt-box{padding:24px 20px;}
  .cnt-box .num{font-size:44px;}
  .cnt-box .lbl{font-size:15px;}

  /* Grenada */
  #grenada{padding:60px 24px;}
  .gren-wrap{grid-template-columns:1fr;gap:40px;}
  .gren-left img{height:220px;}

  /* Contact */
  #contact{}
  .contact-wrap{
    grid-template-columns:1fr;
    padding:50px 24px;
    gap:30px;
  }
  .map-col iframe{min-height:300px;}

  /* Footer */
  #footer{padding:50px 24px 0;}
  .ft-grid{grid-template-columns:1fr 1fr;gap:30px;}
  .ft-bottom{padding:20px 24px;font-size:13px;}

  /* btn-contact fix */
  .btn-contact{margin-right:0;}
}

/* ══════════════════════════════════════
   RESPONSIVE — SMALL MOBILE (max 560px)
═══════════════════════════════════════ */
@media(max-width:560px){

  /* Topbar: stack on very small */
  #topbar{flex-direction:column;align-items:flex-start;gap:8px;padding:10px 16px;}
  .tb-contacts{flex-direction:column;gap:6px;}

  /* Hero */
  .hero-body h1{font-size:24px;}
  .hero-body p{font-size:14px;}
  .btn-pill,.btn-pill-outline{font-size:14px;padding:11px 22px;}

  /* Deals */
  #deals{margin-left:10px;margin-right:10px;padding:20px 16px 26px;}
  .deals-diamonds{gap:20px;}
  .diamond{width:110px;height:110px;}

  /* About */
  .about-imgs{height:280px;}
  .about-img-main{height:260px;}
  .about-img-inset{width:120px;height:120px;bottom:-30px;}

  /* Gallery: 1 column on tiny screens */
  .photos-grid{grid-template-columns:1fr;}

  /* Why */
  .why-text{padding:40px 20px;}
  .why-img-col{min-height:220px;}
  .why-img-col img{height:220px;}

  /* Counters */
  .cnt-row{flex-direction:column;align-items:stretch;}
  .cnt-box{padding:20px 16px;}
  .cnt-box .num{font-size:40px;}

  /* Grenada */
  .gren-name{font-size:20px;}
  .gren-thumb{width:58px;height:58px;}

  /* Contact */
  .contact-wrap{padding:40px 16px;}
  .cf-row{grid-template-columns:1fr;}

  /* Footer */
  .ft-grid{grid-template-columns:1fr;}
  .ft-bottom{
    flex-direction:column;
    text-align:center;
    padding:20px 16px;
    font-size:12px;
  }

  /* Gallery section title */
  .gallery-sec-title h2{font-size:20px;}
}