*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
:root{
  --ink:#0A0A0A;
  --paper:#F4F1EC;
  --mid:#888;
  --light:#D8D4CC;
  --white:#FAFAF8;
  --accent:#C8A96E;
  --display:'Bebas Neue',sans-serif;
  --serif:'DM Serif Display',Georgia,serif;
  --sans:'DM Sans',sans-serif;
}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  overflow-x:hidden;
  cursor:none;
}

/* CURSOR */
#cd {
  position: fixed;
  width: 6px;
  height: 6px;
  background: var(--ink);
  border-radius: 50%;
  pointer-events: none;
  z-index: 9000;
  will-change: transform;
}

#cr {
  position: fixed;
  width: 32px;
  height: 32px;
  border: 1px solid var(--ink);
  border-radius: 50%;
  pointer-events: none;
  z-index: 8999;
  will-change: transform;
}

#cd,
#cr {
  transform: translate(-50%, -50%);
}
/* NAV */
nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.6rem 2.5rem;
  mix-blend-mode:multiply;
}
.nav-logo{
  font-family:var(--display);
  font-size:1.4rem;
  letter-spacing:.15em;
  color:var(--ink);
  text-decoration:none;
  line-height:1;
}
.nav-logo sup{
  font-family:var(--sans);
  font-size:.45rem;
  letter-spacing:.2em;
  font-weight:500;
  vertical-align:super;
  opacity:.6;
}
.nav-menu{display:flex;gap:2.2rem;list-style:none;}
.nav-menu a{
  font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--ink);text-decoration:none;font-weight:500;
  opacity:.55;transition:opacity .3s;
}
.nav-menu a:hover{opacity:1;}
.nav-book{
  font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;
  background:var(--ink);color:var(--paper);
  padding:.65rem 1.4rem;text-decoration:none;font-weight:500;
  transition:background .3s,color .3s;cursor:none;
  border:none;
}
.nav-book:hover{background:var(--accent);color:var(--ink);}
.nav-hamburger{display:none;flex-direction:column;gap:5px;width:32px;cursor:none;background:none;border:none;}
.nav-hamburger span{display:block;width:100%;height:1.5px;background:var(--ink);}

/* MOBILE NAV */
.mobile-menu{
  position:fixed;inset:0;z-index:600;background:var(--ink);
  display:flex;flex-direction:column;justify-content:center;gap:0;
  padding:2.5rem;transform:translateY(-100%);transition:transform .5s cubic-bezier(.16,1,.3,1);
}
.mobile-menu.open{transform:translateY(0);}
.mobile-menu a{
  font-family:var(--display);font-size:2.4rem;color:var(--paper);
  text-decoration:none;padding:.7rem 0;border-bottom:1px solid rgba(255,255,255,.1);
  letter-spacing:.04em;
}
.mobile-close{
  position:absolute;top:1.8rem;right:2rem;background:none;border:none;
  color:var(--paper);font-size:1.6rem;cursor:none;
}

/* HERO */
.hero{
  position:relative;height:100vh;
  overflow:hidden;display:flex;align-items:flex-end;
  background:var(--ink);
}

@keyframes imgIn{to{transform:scale(1);opacity:.65;}}
.hero-img::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,10,10,.85) 0%,rgba(10,10,10,.2) 60%,transparent 100%);
}
.hero-body{
  position:relative;z-index:2;
  width:100%;padding:0 2.5rem 3.5rem;
  display:grid;grid-template-columns:1fr auto;align-items:flex-end;gap:2rem;
}
 .hero-headline{
  font-family:var(--display);
  font-size:clamp(5rem,14vw,13rem);
  line-height:.88;
  color:var(--paper);
  letter-spacing:-.01em;
  min-height:3em;
  will-change:opacity,transform;
  animation:headIn 1.2s .4s cubic-bezier(.16,1,.3,1) forwards;
}
.hero-headline span{
  display:block;
  color:transparent;
  -webkit-text-stroke:1px var(--paper);
}
@keyframes headIn{from{opacity:0;transform:translateY(40px);}to{opacity:1;transform:translateY(0);}}
.hero-side{
  display:flex;flex-direction:column;align-items:flex-end;gap:1.8rem;
  animation:fadeIn 1.4s .8s both;
}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.hero-meta{text-align:right;}
.hero-meta p{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,241,236,.5);margin-bottom:.4rem;}
.hero-meta strong{font-family:var(--serif);font-size:1.1rem;font-weight:400;font-style:italic;color:var(--paper);}
.hero-scroll{
  display:flex;align-items:center;gap:.8rem;
  font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(244,241,236,.4);
}
.scroll-bar{width:36px;height:1px;background:var(--accent);display:block;}

/* SECTION COMMONS */
.sec-num{
  font-family:var(--display);
  font-size:clamp(6rem,15vw,14rem);
  line-height:1;color:transparent;
  -webkit-text-stroke:1px var(--light);
  position:absolute;top:0;right:0;
  pointer-events:none;user-select:none;
  letter-spacing:-.02em;
}
.label{
  font-size:.58rem;letter-spacing:.28em;text-transform:uppercase;
  color:var(--mid);display:flex;align-items:center;gap:.8rem;
  margin-bottom:1.2rem;
}
.label::before{content:'';width:20px;height:1px;background:var(--accent);}
.sec-title{
  font-family:var(--display);
  font-size:clamp(2.8rem,6vw,5.5rem);
  line-height:.92;letter-spacing:.01em;
  color:var(--ink);
}
.sec-title em{
  font-family:var(--serif);font-style:italic;
  color:var(--mid);display:block;
  font-size:.6em;letter-spacing:.02em;
}

/* REVEAL */
.rv{opacity:0;transform:translateY(28px);transition:opacity .9s ease,transform .9s ease;}
.rv.vis{opacity:1;transform:none;}
.rv.d1{transition-delay:.1s;}.rv.d2{transition-delay:.2s;}
.rv.d3{transition-delay:.3s;}.rv.d4{transition-delay:.4s;}

/* STRIP */
.strip{
  background:var(--ink);padding:1.2rem 0;overflow:hidden;
  border-top:1px solid #1a1a1a;border-bottom:1px solid #1a1a1a;
}
.strip-track{
  display:flex;white-space:nowrap;
  animation:strip 30s linear infinite;
}
.strip-item{
  font-family:var(--display);font-size:1.1rem;letter-spacing:.1em;
  color:rgba(244,241,236,.18);padding:0 2rem;flex-shrink:0;
}
.strip-dot{color:var(--accent);padding:0 .5rem;}
@keyframes strip{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* HABITACIONES */
.rooms{padding:8rem 2.5rem;position:relative;background:var(--paper);}
.rooms-intro{
  display:grid;grid-template-columns:1fr 1fr;
  gap:4rem;align-items:flex-end;margin-bottom:5rem;
}
.rooms-body{
  font-size:.9rem;line-height:1.9;color:#555;
  font-weight:300;max-width:380px;
  align-self:flex-end;
}
.rooms-grid{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  grid-template-rows:auto auto;
  gap:1rem;
}
.room-card{position:relative;overflow:hidden;cursor:none;}
.room-card:nth-child(1){grid-column:1/6;grid-row:1;}
.room-card:nth-child(2){grid-column:6/13;grid-row:1;}
.room-card:nth-child(3){grid-column:1/5;grid-row:2;}
.room-card:nth-child(4){grid-column:5/9;grid-row:2;}
.room-card:nth-child(5){grid-column:9/13;grid-row:2;}

.room-img{
  width:100%;object-fit:cover;display:block;
  filter:grayscale(100%);
  transition:filter .7s ease,transform .8s cubic-bezier(.25,.46,.45,.94);
}
.room-card:nth-child(1) .room-img,.room-card:nth-child(2) .room-img{height:480px;}
.room-card:nth-child(3) .room-img,.room-card:nth-child(4) .room-img,.room-card:nth-child(5) .room-img{height:300px;}
.room-card:hover .room-img{filter:grayscale(0%);transform:scale(1.04);}

.room-info{
  position:absolute;bottom:0;left:0;right:0;
  padding:1.6rem;
  background:linear-gradient(to top,rgba(10,10,10,.88) 0%,transparent 100%);
  display:flex;justify-content:space-between;align-items:flex-end;
  pointer-events:none;
}
.room-name{
  font-family:var(--display);font-size:1.6rem;
  color:var(--paper);letter-spacing:.03em;line-height:1;
}
.room-card:nth-child(1) .room-name,.room-card:nth-child(2) .room-name{font-size:2.2rem;}
.room-type{font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:.3rem;}
.room-price{
  font-family:var(--serif);font-size:1.1rem;font-style:italic;
  color:var(--paper);text-align:right;
}
.room-price small{display:block;font-family:var(--sans);font-size:.55rem;letter-spacing:.15em;text-transform:uppercase;color:rgba(244,241,236,.45);font-style:normal;}
.room-link{
  position:absolute;inset:0;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .4s;
  background:rgba(10,10,10,.35);
}
.room-link-btn{
  font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;
  border:1px solid var(--paper);color:var(--paper);
  background:transparent;
  padding:.7rem 1.6rem;text-decoration:none;cursor:none;
  transition:background .3s,color .3s;
  position:relative;z-index:5;
}
.room-link-btn:hover{background:var(--paper);color:var(--ink);}
.room-card:hover .room-link{opacity:1;}

/* EXPERIENCIAS */
.exp{
  background:var(--ink);
  padding:8rem 2.5rem;
  position:relative;overflow:hidden;
}
.exp-grid{
  display:grid;grid-template-columns:1fr 1fr 1fr;
  gap:1px;background:rgba(255,255,255,.08);
  margin-top:5rem;
  border:1px solid rgba(255,255,255,.08);
}
.exp-item{
  padding:3rem 2.5rem;
  background:var(--ink);
  position:relative;overflow:hidden;
  transition:background .4s;cursor:none;
}
.exp-item:hover{background:#111;}
.exp-num{
  font-family:var(--display);font-size:4rem;
  color:rgba(255,255,255,.06);line-height:1;
  margin-bottom:1.8rem;transition:color .4s;
}
.exp-item:hover .exp-num{color:rgba(200,169,110,.15);}
.exp-icon{
  width:32px;height:32px;margin-bottom:1.4rem;
  opacity:.35;transition:opacity .4s;
}
.exp-item:hover .exp-icon{opacity:.8;}
.exp-name{
  font-family:var(--display);font-size:1.6rem;
  color:var(--paper);letter-spacing:.03em;margin-bottom:.8rem;line-height:1;
}
.exp-desc{font-size:.78rem;line-height:1.8;color:rgba(244,241,236,.45);font-weight:300;}
.exp-bar{
  position:absolute;bottom:0;left:0;right:100%;
  height:1px;background:var(--accent);
  transition:right .5s ease;
}
.exp-item:hover .exp-bar{right:0;}
.exp .label::before{background:rgba(200,169,110,.6);}
.exp .label{color:rgba(244,241,236,.4);}
.exp .sec-title{color:var(--paper);}
.exp .sec-title em{color:rgba(244,241,236,.3);}

/* ABOUT */
.about{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:80vh;
}
.about-visual{position:relative;overflow:hidden;min-height:500px;}
.about-img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(100%) contrast(1.05);
  transition:filter .8s;display:block;
}
.about-visual:hover .about-img{filter:grayscale(30%) contrast(1.05);}
.about-year{
  position:absolute;bottom:3rem;left:3rem;
  font-family:var(--display);font-size:7rem;
  color:transparent;-webkit-text-stroke:1px rgba(244,241,236,.3);
  line-height:1;pointer-events:none;
}
.about-text{
  padding:6rem 5rem;
  display:flex;flex-direction:column;justify-content:center;
  background:var(--white);position:relative;
}
.about-quote{
  font-family:var(--serif);font-size:clamp(1.4rem,2.5vw,2rem);
  font-style:italic;line-height:1.5;color:var(--ink);
  border-left:2px solid var(--accent);padding-left:2rem;
  margin:2.5rem 0;
}
.about-body{font-size:.85rem;line-height:1.95;color:#555;font-weight:300;}
.about-stats{
  display:flex;gap:3rem;margin-top:3rem;
  padding-top:2.5rem;border-top:1px solid var(--light);
}
.stat-n{
  font-family:var(--display);font-size:3rem;
  color:var(--ink);line-height:1;display:block;
}
.stat-l{font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);margin-top:.3rem;display:block;}

/* GALERÍA */
.gallery{padding:8rem 2.5rem;background:var(--paper);position:relative;}
.gallery-strip{
  display:flex;gap:1rem;margin-top:4rem;
  margin-left:-2.5rem;margin-right:-2.5rem;
  padding:0 2.5rem;
  overflow-x:auto;scrollbar-width:none;
}
.gallery-strip::-webkit-scrollbar{display:none;}
.gal-item{flex-shrink:0;position:relative;overflow:hidden;cursor:none;}
.gal-item:nth-child(odd){width:320px;height:420px;}
.gal-item:nth-child(even){width:260px;height:420px;margin-top:4rem;}
.gal-img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(100%);display:block;
  transition:filter .7s ease,transform .8s ease;
}
.gal-item:hover .gal-img{filter:grayscale(0%);transform:scale(1.05);}

/* RESERVA */
.booking{
  background:var(--ink);
  padding:6rem 2.5rem;
  display:grid;grid-template-columns:1fr 1fr;
  gap:6rem;align-items:center;
}
.booking .label::before{background:rgba(200,169,110,.5);}
.booking .label{color:rgba(244,241,236,.4);}
.booking .sec-title{color:var(--paper);}
.booking .sec-title em{color:rgba(244,241,236,.3);}
.booking-desc{font-size:.85rem;line-height:1.9;color:rgba(244,241,236,.45);font-weight:300;margin-top:1.5rem;}
.booking-form{display:flex;flex-direction:column;gap:0;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:0;}
.f-group{border-bottom:1px solid rgba(255,255,255,.1);padding:1.4rem 0;position:relative;}
.f-group:not(:last-child){border-right:1px solid rgba(255,255,255,.06);}
.f-label{
  font-size:.52rem;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(244,241,236,.3);display:block;margin-bottom:.5rem;
  padding:0 1.4rem;
}
.f-input,.f-select{
  width:100%;background:transparent;border:none;outline:none;
  font-family:var(--sans);font-size:.9rem;color:var(--paper);
  padding:0 1.4rem;transition:color .3s;cursor:none;
}
.f-input::placeholder{color:rgba(244,241,236,.3);}
.f-select{-webkit-appearance:none;color:rgba(244,241,236,.6);}
.f-select option{background:var(--ink);}
.f-group::after{
  content:'';position:absolute;bottom:-1px;left:0;right:100%;
  height:1px;background:var(--accent);transition:right .4s ease;
}
.f-group:focus-within::after{right:0;}
.btn-book{
  margin-top:2rem;
  display:flex;align-items:center;justify-content:space-between;
  padding:1.3rem 2rem;
  background:var(--paper);color:var(--ink);
  font-family:var(--display);font-size:1.1rem;
  letter-spacing:.08em;border:none;cursor:none;
  transition:background .3s,color .3s;
}
.btn-book:hover{background:var(--accent);color:var(--ink);}
.btn-book svg{transition:transform .3s;}
.btn-book:hover svg{transform:translateX(6px);}

/* TESTIMONIOS */
.reviews{
  padding:8rem 2.5rem;background:var(--white);
  position:relative;overflow:hidden;
}
.reviews-grid{
  display:grid;grid-template-columns:1fr 1fr 1fr;
  gap:2rem;margin-top:5rem;
}
.review-card{
  padding:2.5rem;border:1px solid var(--light);
  position:relative;transition:border-color .3s;cursor:none;
}
.review-card:hover{border-color:var(--accent);}
.review-stars{
  display:flex;gap:3px;margin-bottom:1.4rem;
}
.star{
  width:10px;height:10px;background:var(--accent);
  clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%);
}
.review-text{
  font-family:var(--serif);font-size:1rem;font-style:italic;
  line-height:1.7;color:var(--ink);margin-bottom:1.8rem;
}
.review-author{
  display:flex;align-items:center;gap:.8rem;
}
.review-avatar{
  width:36px;height:36px;border-radius:50%;object-fit:cover;
  filter:grayscale(80%);
}
.review-name{font-size:.75rem;font-weight:500;color:var(--ink);}
.review-origin{font-size:.6rem;color:var(--mid);letter-spacing:.08em;}

/* LOCALIZACIÓN */
.location{
  display:grid;grid-template-columns:1fr 1fr;
  min-height:60vh;
}
.location-map{
  background:var(--ink);position:relative;overflow:hidden;
}
.map-img{
  width:100%;height:100%;object-fit:cover;
  filter:grayscale(100%) invert(1) contrast(.8);
  opacity:.6;display:block;
}
.map-pin{
  position:absolute;top:50%;left:50%;
  width:12px;height:12px;background:var(--accent);border-radius:50%;
  transform:translate(-50%,-50%);
}
.map-pin::before{
  content:'';position:absolute;
  width:30px;height:30px;border:1px solid var(--accent);
  border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{transform:translate(-50%,-50%) scale(1);opacity:.6;}50%{transform:translate(-50%,-50%) scale(1.8);opacity:0;}}
.location-info{
  background:var(--paper);
  padding:5rem 4rem;
  display:flex;flex-direction:column;justify-content:center;
}
.location-address{
  font-family:var(--display);font-size:2.5rem;
  line-height:1;color:var(--ink);margin:2rem 0;
}
.location-detail{
  font-size:.78rem;line-height:2;color:#555;font-weight:300;
  padding:1.5rem 0;border-top:1px solid var(--light);
}
.location-links{display:flex;gap:1.5rem;margin-top:1.5rem;flex-wrap:wrap;}
.loc-link{
  font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink);text-decoration:none;border-bottom:1px solid var(--light);
  padding-bottom:3px;transition:border-color .3s,color .3s;
  background:none;border-top:none;border-left:none;border-right:none;
}
.loc-link:hover{border-color:var(--accent);color:var(--accent);}

/* FOOTER */
footer{
  background:var(--ink);
  padding:5rem 2.5rem 2rem;
}
.footer-top{
  display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:4rem;padding-bottom:4rem;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.f-brand{
  font-family:var(--display);font-size:2rem;
  letter-spacing:.15em;color:var(--paper);display:block;margin-bottom:1rem;
}
.f-tagline{font-size:.75rem;line-height:1.8;color:rgba(244,241,236,.35);font-weight:300;}
.f-col-title{
  font-size:.55rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1.5rem;
}
.f-links{list-style:none;display:flex;flex-direction:column;gap:.7rem;}
.f-links a{font-size:.78rem;color:rgba(244,241,236,.4);text-decoration:none;font-weight:300;transition:color .3s;}
.f-links a:hover{color:var(--paper);}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:2rem;flex-wrap:wrap;gap:.8rem;
}
.f-copy{font-size:.58rem;letter-spacing:.1em;color:rgba(244,241,236,.2);}
.f-copy span{color:var(--accent);}

/* ============================================================
   ROOM MODAL
   ============================================================ */
.room-modal-overlay{
  position:fixed;inset:0;z-index:8000;
  background:rgba(10,10,10,.92);
  display:flex;align-items:center;justify-content:center;
  padding:2rem;
  opacity:0;pointer-events:none;
  transition:opacity .4s ease;
}
.room-modal-overlay.open{opacity:1;pointer-events:all;}
.room-modal{
  background:var(--white);
  width:100%;max-width:980px;max-height:88vh;
  overflow-y:auto;
  display:grid;grid-template-columns:1fr 1fr;
  transform:translateY(30px) scale(.98);
  transition:transform .45s cubic-bezier(.16,1,.3,1);
}
.room-modal-overlay.open .room-modal{transform:translateY(0) scale(1);}
.room-modal-visual{position:relative;min-height:340px;background:var(--ink);}
.room-modal-img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(40%);}
.room-modal-type{
  position:absolute;top:1.5rem;left:1.5rem;
  font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--paper);background:rgba(10,10,10,.5);
  padding:.5rem 1rem;backdrop-filter:blur(6px);
}
.room-modal-close{
  position:absolute;top:1.5rem;right:1.5rem;z-index:10;
  width:36px;height:36px;border-radius:50%;
  background:rgba(10,10,10,.5);backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.2);color:var(--paper);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;cursor:none;transition:background .3s,border-color .3s;
}
.room-modal-close:hover{background:var(--accent);border-color:var(--accent);color:var(--ink);}
.room-modal-body{padding:3rem 2.5rem;display:flex;flex-direction:column;}
.room-modal-name{
  font-family:var(--display);font-size:2.6rem;line-height:1;
  color:var(--ink);letter-spacing:.02em;margin-bottom:1rem;
}
.room-modal-desc{font-size:.85rem;line-height:1.85;color:#555;font-weight:300;margin-bottom:1.6rem;}
.room-modal-amenities{
  display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:1.8rem;
}
.room-modal-chip{
  font-size:.62rem;letter-spacing:.1em;text-transform:uppercase;
  border:1px solid var(--light);padding:.4rem .9rem;color:#555;
}
.room-modal-footer{
  margin-top:auto;display:flex;justify-content:space-between;align-items:center;
  border-top:1px solid var(--light);padding-top:1.6rem;gap:1rem;flex-wrap:wrap;
}
.room-modal-price{font-family:var(--serif);font-size:1.6rem;font-style:italic;color:var(--ink);}
.room-modal-price small{display:block;font-family:var(--sans);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;color:var(--mid);font-style:normal;margin-top:.2rem;}
.room-modal-cta{
  display:flex;align-items:center;gap:.6rem;
  background:var(--ink);color:var(--paper);
  font-family:var(--display);font-size:.95rem;letter-spacing:.06em;
  padding:.85rem 1.6rem;text-decoration:none;border:none;cursor:none;
  transition:background .3s,color .3s;
}
.room-modal-cta:hover{background:var(--accent);color:var(--ink);}

@media(max-width:860px){
  .room-modal{grid-template-columns:1fr;max-height:92vh;}
  .room-modal-visual{min-height:220px;}
  .room-modal-body{padding:2rem 1.6rem;}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1100px){
  .rooms-grid{grid-template-columns:repeat(6,1fr);}
  .room-card:nth-child(1){grid-column:1/7;}
  .room-card:nth-child(2){grid-column:1/7;grid-row:2;}
  .room-card:nth-child(3){grid-column:1/7;grid-row:3;}
  .room-card:nth-child(4){grid-column:1/7;grid-row:4;}
  .room-card:nth-child(5){grid-column:1/7;grid-row:5;}
  .room-card .room-img{height:340px!important;}
  .exp-grid{grid-template-columns:1fr 1fr;}
  .about{grid-template-columns:1fr;}
  .about-text{padding:4rem 2.5rem;}
  .location{grid-template-columns:1fr;}
  .footer-top{grid-template-columns:1fr 1fr;gap:2.5rem;}
}
@media(max-width:720px){
  body{cursor:auto;}
  .c-dot,.c-ring{display:none;}
  .nav-menu{display:none;}
  .nav-hamburger{display:flex;}
  .hero-body{grid-template-columns:1fr;}
  .hero-side{align-items:flex-start;margin-top:2rem;}
  .hero-meta{text-align:left;}
  .rooms,.exp,.gallery,.booking,.reviews{padding:5rem 1.5rem;}
  .rooms-intro{grid-template-columns:1fr;gap:2rem;}
  .exp-grid{grid-template-columns:1fr;}
  .booking{grid-template-columns:1fr;gap:3rem;}
  .form-row{grid-template-columns:1fr;}
  .f-group:not(:last-child){border-right:none;}
  .reviews-grid{grid-template-columns:1fr;gap:1.5rem;}
  .about-text{padding:3rem 1.5rem;}
  .location-info{padding:3rem 1.5rem;}
  .footer-top{grid-template-columns:1fr;gap:2.5rem;}
  .room-link{opacity:1;background:rgba(10,10,10,.15);}
  .room-link-btn{padding:.55rem 1.2rem;font-size:.55rem;}
}