/* =========================================================
   LA MARINA HOTEL — MAIN STYLESHEET
   Uses tokens defined in tokens.css (load tokens.css first).
   Class prefix: lm-
   ========================================================= */

/* ---------- Base / Reset ---------- */
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--lm-bg);
  color:var(--lm-ink);
  font-family:var(--lm-font-body);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; }
button{ font:inherit; }
::selection{ background:var(--lm-accent); color:var(--lm-primary-dark); }


.text__yellow{ color:var(--lm-accent); }

/* ---------- Layout helpers ---------- */
.lm-container{    
  width: 100%;
  max-width:var(--lm-container);
  margin:0 auto;
}
.lm-container--wide{ 
  max-width:var(--lm-container-wide); 
  width: 100%;
}

.lm-section-head{
  margin-bottom:clamp(36px,4vw,56px);
}
.lm-section-head--center{
  text-align:center;
  max-width:640px;
  margin-left:auto;
  margin-right:auto;
}

.lm-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:12px;
  font-weight:700;
  letter-spacing:.26em;
  text-transform:uppercase;
  color:var(--lm-primary);
  margin-bottom:18px;
}
.lm-eyebrow--center{ display:inline-block; margin-bottom:16px; }
.lm-eyebrow__dash{
  width:26px;
  height:1px;
  background:var(--lm-green);
  display:inline-block;
}

.lm-section-title{
  font-family:var(--lm-font-heading);
  font-weight:500;
  font-size:var(--lm-fs-section-title);
  line-height:1.04;
  letter-spacing:-.01em;
  color:var(--lm-ink);
  margin:0 0 20px;
}
.lm-italic{ font-style:italic; color:var(--lm-primary); }

.lm-body-text{
  font-size:var(--lm-fs-body);
  line-height:1.75;
  color:var(--lm-text-muted);
  max-width:540px;
  margin:0 0 4px;
}
.lm-body-text--center{ margin-left:auto; margin-right:auto; }

/* ---------- Buttons & chips ---------- */
.lm-btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  font-weight:700;
  font-size:15px;
  padding:17px 34px;
  border-radius:var(--lm-radius-pill);
  border:none;
  cursor:pointer;
  transition:transform var(--lm-dur-fast), box-shadow var(--lm-dur-fast), background var(--lm-dur-fast);
}
.lm-btn--accent{
  background:var(--lm-accent);
  color:var(--lm-ink);
  box-shadow:var(--lm-shadow-accent);
}
.lm-btn--accent:hover{ transform:translateY(-3px); }
.lm-btn--ghost{
  background:rgba(var(--lm-white-rgb), .12);
  backdrop-filter:blur(8px);
  color:var(--lm-white);
  border:1px solid rgba(var(--lm-white-rgb), .5);
  font-weight:600;
}
.lm-btn--ghost:hover{ background:rgba(var(--lm-white-rgb), .24); }
.lm-btn--lg{ padding:18px 40px; font-size:16px; }

.lm-trust-chip{
  display:inline-flex;
  align-items:center;
  font-size:13.5px;
  font-weight:600;
  color:rgba(var(--lm-white-rgb), .96);
  letter-spacing:.01em;
}

.lm-link-btn{
  display:inline-flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  font-weight:700;
  font-size:15px;
  color:var(--lm-primary);
  padding:14px 28px;
  border:1px solid rgba(var(--lm-primary-rgb), .35);
  border-radius:var(--lm-radius-pill);
  background:transparent;
  transition:all var(--lm-dur-fast);
}
.lm-link-btn:hover{
  background:var(--lm-primary);
  color:var(--lm-white);
  border-color:var(--lm-primary);
}

/* ---------- Decorative floral icon (shared <symbol>, reused via <use>) ---------- */
.lm-sprite{ position:absolute; width:0; height:0; overflow:hidden; }
.lm-flower{ display:inline-flex; flex:none; }

/* ---------- Header ---------- */
.lm-header{
  position:relative;
  /* top:0; left:0; right:0; */
  z-index:50;
  color:var(--lm-white);
  background:transparent;
  transition:background var(--lm-dur-slow), box-shadow var(--lm-dur-slow), backdrop-filter var(--lm-dur-slow), color var(--lm-dur-slow);
}
.lm-header.is-scrolled{
    position:fixed;
  top:0; left:0; right:0;
  background:rgba(250,248,245,.88);
  backdrop-filter:blur(16px);
  box-shadow:0 8px 30px -18px rgba(var(--lm-primary-rgb), .5);
  color:var(--lm-ink);
}
.lm-header__inner{
  width: 100%;
  /* max-width:var(--lm-container-wide); */
  margin:0 auto;
  padding:0 var(--lm-gutter);
  height:78px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.lm-header__brand{
  display:flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  /* color:inherit; */
  color:var(--lm-primary);
}
.lm-header__logo{
  width:34px; height:34px;
  --lm-flower-petal:var(--lm-gold);
  --lm-flower-center:var(--lm-primary);
}
.lm-header__brand-text{ display:flex; flex-direction:column; line-height:1; }
.lm-header__brand-name{
  font-family:var(--lm-font-heading);
  font-size:3rem;
  font-weight:600;
  letter-spacing:0;
}
.lm-header__brand-sub{
  font-size:1.4rem;
  font-weight:600;
  letter-spacing:.22em;
  opacity:.62;
  margin-top:3px;
}
.lm-header__nav{ display:flex; align-items:center; gap:30px; }
.lm-header__nav-link{
  text-decoration:none;
  /* color:inherit; */
  color:var(--lm-primary);
  font-size:14px;
  font-weight:600;
  opacity:.92;
  letter-spacing:.01em;
}
.lm-header__cta{
  text-decoration:none;
  font-size:14px;
  font-weight:700;
  padding:11px 22px;
  border-radius:var(--lm-radius-pill);
  border:1px solid rgba(var(--lm-primary-rgb), .6);
  /* color:var(--lm-white); */
  color:var(--lm-primary);
  background:rgba(var(--lm-white-rgb), .1);
  transition:all var(--lm-dur-fast);
  white-space:nowrap;
}
.lm-header.is-scrolled .lm-header__cta{
  border-color:rgba(var(--lm-primary-rgb), .4);
  color:var(--lm-primary);
  background:rgba(var(--lm-white-rgb), .5);
}
.lm-header__cta:hover{
  background:var(--lm-primary);
  color:var(--lm-white);
  border-color:var(--lm-primary);
}

/* ---------- Hero ---------- */
.lm-hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  padding:120px var(--lm-gutter) 160px;
  overflow:hidden;
}
.lm-hero__bg{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
  background:linear-gradient(180deg,#5b96ab,#2f6175);
}
.lm-hero__gradient{
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg,rgba(var(--lm-primary-dark-rgb),.50) 0%,rgba(var(--lm-primary-dark-rgb),.18) 38%,rgba(var(--lm-primary-dark-rgb),.30) 72%,rgba(var(--lm-primary-dark-rgb),.66) 100%);
}
.lm-hero__radial{
  position:absolute; inset:0; z-index:1;
  background:radial-gradient(120% 80% at 18% 30%, rgba(var(--lm-primary-rgb),.34), transparent 60%);
}
.lm-hero__floral{
  position:absolute;
  z-index:2;
  color:rgba(var(--lm-white-rgb), .5);
  animation:lm-drift 9s ease-in-out infinite;
  --lm-flower-petal:currentColor;
  --lm-flower-center:var(--lm-accent);
}
.lm-hero__floral--1{ top:22%; right:9%; width:46px; height:46px; }
.lm-hero__floral--2{
  top:auto; bottom:30%; left:7%;
  width:30px; height:30px;
  color:rgba(var(--lm-white-rgb), .38);
  animation-duration:11s;
  animation-delay:1.5s;
}
.lm-hero__inner{
  position:relative;
  z-index:3;
  max-width:var(--lm-container-wide);
  width:100%;
  margin:0 auto;
  color:var(--lm-white);
}
.lm-hero__content{
  max-width:720px;
  animation:lm-rise .9s ease both;
}
.lm-hero__eyebrow{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-size:12px;
  font-weight:600;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--lm-accent);
  margin-bottom:26px;
}
.lm-hero__eyebrow-line{ width:30px; height:1px; background:var(--lm-accent); }
.lm-hero__title{
  font-family:var(--lm-font-heading);
  font-weight:500;
  font-size:var(--lm-fs-hero-title);
  line-height:.98;
  letter-spacing:-.01em;
  margin:0 0 24px;
  text-shadow:0 2px 40px rgba(var(--lm-primary-dark-rgb),.35);
}
.lm-hero__title-italic{ font-style:italic; color:var(--lm-accent-soft); }
.lm-hero__lead{
  font-size:clamp(17px,2vw,21px);
  line-height:1.6;
  max-width:560px;
  color:rgba(var(--lm-white-rgb), .92);
  margin:0 0 38px;
  font-weight:400;
}
.lm-hero__actions{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  margin-bottom:42px;
}
.lm-hero__trust{
  display:flex;
  flex-wrap:wrap;
  gap:10px 22px;
}
.lm-hero__scroll{
  position:absolute;
  bottom:38px;
  left:50%;
  transform:translateX(-50%);
  z-index:3;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:9px;
  color:rgba(var(--lm-white-rgb), .8);
}
.lm-hero__scroll-label{
  font-size:10px;
  letter-spacing:.3em;
  text-transform:uppercase;
}
.lm-hero__scroll-track{
  width:24px;
  height:38px;
  border:1.5px solid rgba(var(--lm-white-rgb), .6);
  border-radius:14px;
  position:relative;
  display:inline-block;
}
.lm-hero__scroll-dot{
  position:absolute;
  left:50%;
  top:8px;
  margin-left:-2.5px;
  width:5px;
  height:5px;
  border-radius:50%;
  background:var(--lm-accent);
  animation:lm-scrolldot 1.8s ease-in-out infinite;
}

/* ---------- Quick booking bar ---------- */
.lm-booking{
  position:relative;
  z-index:5;
  margin-top:-78px;
  padding:0 var(--lm-gutter);
}
.lm-booking__card{
  max-width:1120px;
  margin:0 auto;
  background:rgba(var(--lm-white-rgb), .72);
  backdrop-filter:blur(22px);
  border:1px solid rgba(var(--lm-white-rgb), .8);
  border-radius:var(--lm-radius-xl);
  box-shadow:0 30px 80px -30px rgba(var(--lm-primary-rgb), .45);
  padding:26px clamp(22px,3vw,38px);
}
.lm-booking__row{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-end;
  gap:18px;
}
.lm-booking__field{ flex:1 1 180px; min-width:150px; }
.lm-field-label{
  display:block;
  font-size:11px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--lm-primary);
  margin-bottom:8px;
}
.lm-field-input{
  width:100%;
  padding:13px 14px;
  border:1px solid rgba(var(--lm-primary-rgb), .2);
  border-radius:var(--lm-radius-xs);
  background:rgba(var(--lm-white-rgb), .85);
  font-family:var(--lm-font-body);
  font-size:15px;
  color:var(--lm-ink);
  outline:none;
}
.lm-booking__submit{
  flex:0 0 auto;
  background:var(--lm-primary);
  color:var(--lm-white);
  padding:16px 32px;
  border-radius:14px;
  font-weight:700;
  font-size:15px;
  box-shadow:var(--lm-shadow-btn);
  transition:background var(--lm-dur-fast), transform .2s;
}
.lm-booking__submit:hover{ background:var(--lm-primary-light); transform:translateY(-2px); }
.lm-booking__message{
  margin:16px 2px 0;
  font-size:14px;
  color:var(--lm-primary);
  font-weight:600;
}
.lm-booking__message[hidden]{ display:none; }

/* ---------- About ---------- */
.lm-about{
  padding:clamp(80px,11vw,150px) var(--lm-gutter) clamp(60px,8vw,100px);
  position:relative;
}
.lm-about__bg-icon{
  position:absolute;
  top:8%; right:4%;
  width:200px; height:200px;
  color:rgba(79,125,89,.07);
  animation:lm-spin 60s linear infinite;
  pointer-events:none;
  --lm-flower-petal:currentColor;
  --lm-flower-center:currentColor;
}
.lm-about__grid{
  display:grid;
  grid-template-columns:1.05fr 1fr;
  gap:clamp(36px,5vw,80px);
  align-items:center;
}
.lm-about__media{ position:relative; }
.lm-about__img{ object-fit:cover; }
.lm-about__img--main{
  width:100%;
  height:clamp(360px,42vw,560px);
  border-radius:24px;
  box-shadow:var(--lm-shadow-card-lg);
}
.lm-about__img--sub{
  position:absolute;
  bottom:-34px;
  right:-26px;
  width:42%;
  height:200px;
  border-radius:18px;
  border:6px solid var(--lm-bg);
  box-shadow:0 24px 50px -24px rgba(var(--lm-primary-rgb), .45);
}
.lm-about__badge{
  position:absolute;
  top:-26px;
  left:-22px;
  background:var(--lm-white);
  border-radius:18px;
  padding:16px 22px;
  box-shadow:var(--lm-shadow-pop);
  display:flex;
  align-items:center;
  gap:12px;
}
.lm-about__badge-rating{
  font-family:var(--lm-font-heading);
  font-size:34px;
  font-weight:600;
  color:var(--lm-primary);
  line-height:1;
}
.lm-about__badge-label{ font-size:12px; line-height:1.4; color:var(--lm-text-muted); }

.lm-about__list{
  list-style:none;
  margin:30px 0 36px;
  padding:0;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px 28px;
}
.lm-about__item{
  display:flex;
  align-items:center;
  gap:11px;
  font-size:15px;
  font-weight:600;
  color:var(--lm-ink-soft);
}
.lm-about__dot{
  width:9px; height:9px;
  border-radius:50%;
  flex:0 0 9px;
  background:var(--lm-green);
  box-shadow:0 0 0 4px rgba(79,125,89,.14);
}

/* ---------- Experience (bento grid) ---------- */
.lm-experience{
  padding:clamp(70px,9vw,120px) var(--lm-gutter);
  background:var(--lm-white);
}
.lm-experience__grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  grid-auto-rows:280px;
  gap:18px;
}
.lm-exp-card{
  grid-column:span 2;
  position:relative;
  border-radius:var(--lm-radius-md);
  overflow:hidden;
  box-shadow:var(--lm-shadow-card);
}
.lm-exp-card--wide{ grid-column:span 4; }
.lm-exp-card__img{ width:100%; height:100%; object-fit:cover; }
.lm-exp-card__caption{
  position:absolute;
  left:0; right:0; bottom:0;
  padding:46px 22px 20px;
  background:linear-gradient(180deg, transparent, rgba(var(--lm-primary-dark-rgb),.82));
  color:var(--lm-white);
  font-size:13.5px;
  line-height:1.5;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.lm-exp-card__title{
  font-family:var(--lm-font-heading);
  font-size:23px;
  font-weight:600;
  line-height:1;
}

/* ---------- Rooms ---------- */
.lm-rooms{
  padding:clamp(80px,10vw,130px) var(--lm-gutter);
  position:relative;
}
.lm-rooms__head{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
}
.lm-rooms__head-text{ max-width:560px; }
.lm-rooms__head-desc{ max-width:380px; margin:0; }
.lm-rooms__grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:26px;
}
.lm-room-card{
  background:var(--lm-white);
  border-radius:22px;
  overflow:hidden;
  border:1px solid rgba(var(--lm-primary-rgb), .08);
  box-shadow:var(--lm-shadow-card);
  display:flex;
  flex-direction:column;
}
.lm-room-card__media{ position:relative; }
.lm-room-card__img{ width:100%; height:220px; object-fit:cover; }
.lm-room-card__tag{
  position:absolute;
  top:14px; left:14px;
  background:rgba(var(--lm-accent-rgb), .95);
  color:#5a4a12;
  font-size:11px;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:6px 12px;
  border-radius:var(--lm-radius-pill);
}
.lm-room-card__body{ padding:24px 24px 26px; }
.lm-room-card__name{
  font-family:var(--lm-font-heading);
  font-size:26px;
  font-weight:600;
  margin:0 0 10px;
  color:var(--lm-ink);
}
.lm-room-card__meta{
  display:flex;
  align-items:center;
  gap:9px;
  font-size:13px;
  color:var(--lm-text-mute-2);
  font-weight:600;
  margin-bottom:16px;
}
.lm-room-card__meta-dot{
  width:3px; height:3px;
  border-radius:50%;
  background:var(--lm-border-faint);
  display:inline-block;
}
.lm-room-card__price{ margin-bottom:18px; }
.lm-room-card__price-from{ font-size:14px; color:var(--lm-text-mute-3); margin-right:6px; }
.lm-room-card__price-amount{
  font-family:var(--lm-font-heading);
  font-size:32px;
  font-weight:600;
  color:var(--lm-primary);
}
.lm-room-card__price-unit{ font-size:14px; color:var(--lm-text-mute-3); margin-left:5px; }
.lm-room-card__actions{ display:flex; gap:10px; }
.lm-btn--book{
  flex:1;
  background:var(--lm-primary-light);
  color:var(--lm-white);
  border:none;
  padding:12px;
  border-radius:var(--lm-radius-xs);
  font-weight:700;
  font-size:14px;
  cursor:pointer;
  transition:background var(--lm-dur-fast);
}
.lm-btn--book:hover{ background:var(--lm-primary); }
.lm-btn--outline{
  flex:1;
  background:transparent;
  color:var(--lm-text-muted);
  border:1px solid rgba(var(--lm-primary-rgb), .25);
  padding:12px;
  border-radius:var(--lm-radius-xs);
  font-weight:600;
  font-size:14px;
  cursor:pointer;
  transition:all var(--lm-dur-fast);
}
.lm-btn--outline:hover{ border-color:var(--lm-primary); color:var(--lm-primary); }
.lm-room-card__details{
  margin:14px 0 0;
  font-size:13.5px;
  line-height:1.6;
  color:var(--lm-text-muted);
  border-top:1px solid rgba(var(--lm-primary-rgb), .1);
  padding-top:14px;
}
.lm-room-card__details[hidden]{ display:none; }

/* ---------- Why choose us ---------- */
.lm-why{
  padding:clamp(70px,9vw,120px) var(--lm-gutter);
  background:var(--lm-bg-tan);
  position:relative;
  overflow:hidden;
}
.lm-why__grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(210px,1fr));
  gap:16px;
}
.lm-why-card{
  background:rgba(var(--lm-white-rgb), .62);
  border:1px solid rgba(var(--lm-white-rgb), .7);
  border-radius:18px;
  padding:26px 20px;
  text-align:center;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:14px;
  backdrop-filter:blur(6px);
  transition:transform var(--lm-dur-fast), box-shadow var(--lm-dur-fast);
}
.lm-why-card:hover{ transform:translateY(-4px); box-shadow:var(--lm-shadow-pop); }
.lm-why-card__icon{
  font-size:30px;
  line-height:1;
  width:62px; height:62px;
  border-radius:50%;
  background:var(--lm-white);
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 12px 28px -16px rgba(var(--lm-primary-rgb), .5);
}
.lm-why-card__title{ font-size:14.5px; font-weight:700; color:var(--lm-ink-faint); line-height:1.35; }

/* ---------- Gallery ---------- */
.lm-gallery{ padding:clamp(80px,10vw,130px) var(--lm-gutter); }
.lm-gallery__head{
  display:flex;
  flex-wrap:wrap;
  align-items:flex-end;
  justify-content:space-between;
  gap:18px;
}
.lm-gallery__head-desc{ max-width:340px; margin:0; }
.lm-gallery__masonry{ columns:4 240px; column-gap:16px; }
.lm-gallery__img{
  width:100%;
  margin:0 0 16px;
  break-inside:avoid;
  object-fit:cover;
  border-radius:var(--lm-radius-xs);
}
.lm-gallery__img--tall{ height:360px; }
.lm-gallery__img--mid{ height:270px; }
.lm-gallery__img--short{ height:200px; }

/* ---------- Reviews ---------- */
.lm-reviews{
  padding:clamp(76px,9vw,120px) var(--lm-gutter);
  background:var(--lm-primary-dark);
  color:var(--lm-white);
  position:relative;
  overflow:hidden;
}
.lm-reviews__bg-icon{
  position:absolute;
  bottom:-60px; left:-40px;
  width:280px; height:280px;
  color:rgba(var(--lm-white-rgb), .04);
  animation:lm-spin 80s linear infinite;
  pointer-events:none;
  --lm-flower-petal:currentColor;
  --lm-flower-center:currentColor;
}
.lm-reviews__head{ text-align:center; margin-bottom:clamp(40px,5vw,58px); position:relative; z-index:1; }
.lm-reviews__stars{ font-size:30px; letter-spacing:6px; color:var(--lm-accent); margin-bottom:14px; }
.lm-reviews__title{
  font-family:var(--lm-font-heading);
  font-size:clamp(32px,4.5vw,52px);
  font-weight:500;
  margin:0 0 10px;
}
.lm-reviews__subtitle{ color:rgba(var(--lm-white-rgb), .66); margin:0; font-size:15px; }
.lm-reviews__sources{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:12px;
  margin-top:22px;
}
.lm-review-source{
  background:rgba(var(--lm-white-rgb), .12);
  border:1px solid rgba(var(--lm-white-rgb), .18);
  padding:8px 16px;
  border-radius:var(--lm-radius-pill);
  font-size:13px;
  font-weight:600;
  color:var(--lm-white);
}
.lm-reviews__grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:22px;
  position:relative;
  z-index:1;
}
.lm-review-card{
  background:rgba(var(--lm-white-rgb), .06);
  border:1px solid rgba(var(--lm-white-rgb), .12);
  border-radius:var(--lm-radius-md);
  padding:30px 26px;
  backdrop-filter:blur(6px);
}
.lm-review-card__stars{ color:var(--lm-accent); letter-spacing:3px; margin-bottom:14px; }
.lm-review-card__text{
  font-family:var(--lm-font-heading);
  font-size:21px;
  line-height:1.5;
  color:var(--lm-white);
  font-style:italic;
  margin:0 0 22px;
}
.lm-review-card__who{ display:flex; align-items:center; gap:13px; }
.lm-review-card__avatar{
  width:46px; height:46px;
  flex:0 0 46px;
  border-radius:50%;
  object-fit:cover;
  background:rgba(var(--lm-white-rgb), .15);
}
.lm-review-card__name{ display:block; font-size:14px; font-weight:700; color:var(--lm-white); }
.lm-review-card__loc{ display:block; font-size:12px; color:rgba(var(--lm-white-rgb), .55); margin-top:2px; }

/* ---------- Explore Mui Ne ---------- */
.lm-explore{ padding:clamp(80px,10vw,130px) var(--lm-gutter); }
.lm-explore__grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:18px;
}
.lm-explore-card{
  position:relative;
  display:block;
  border-radius:var(--lm-radius-md);
  overflow:hidden;
  height:240px;
  text-decoration:none;
  box-shadow:var(--lm-shadow-card);
  transition:transform .35s var(--lm-ease);
}
.lm-explore-card:hover{ transform:translateY(-6px); }
.lm-explore-card__img{ width:100%; height:100%; object-fit:cover; }
.lm-explore-card__overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 40%, rgba(var(--lm-primary-dark-rgb),.8));
}
.lm-explore-card__label{
  position:absolute;
  width:100%;
  padding:0 20px;
  left:0px; bottom:18px;
  color:var(--lm-white);
  display:flex;
  flex-direction:column;
  gap:4px;
}
.lm-explore-card__title{ font-family:var(--lm-font-heading); font-size:24px; font-weight:600; }
.lm-explore-card__more{ font-size:12.5px; font-weight:600; letter-spacing:.04em; color:var(--lm-accent); }

/* ---------- Special offers ---------- */
.lm-offers{ padding:clamp(70px,9vw,120px) var(--lm-gutter); background:var(--lm-white); }
.lm-offers__grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
}
.lm-offer-card{
  display:flex;
  background:var(--lm-bg);
  border:1px solid rgba(var(--lm-primary-rgb), .08);
  border-radius:22px;
  overflow:hidden;
  box-shadow:var(--lm-shadow-card);
}
.lm-offer-card__img{ width:42%; min-width:140px; height:auto; align-self:stretch; object-fit:cover; }
.lm-offer-card__body{
  padding:28px 26px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:10px;
  flex:1;
}
.lm-offer-card__badge{
  background:var(--lm-green);
  color:var(--lm-white);
  font-size:11px;
  font-weight:700;
  letter-spacing:.06em;
  text-transform:uppercase;
  padding:6px 12px;
  border-radius:var(--lm-radius-pill);
}
.lm-offer-card__title{
  font-family:var(--lm-font-heading);
  font-size:25px;
  font-weight:600;
  margin:2px 0 0;
  color:var(--lm-ink);
}
.lm-offer-card__text{ font-size:14px; line-height:1.6; color:var(--lm-text-muted); margin:0; }
.lm-offer-card__link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:6px;
  color:var(--lm-primary);
  font-weight:700;
  font-size:14px;
  text-decoration:none;
  transition:gap var(--lm-dur-fast);
}
.lm-offer-card__link:hover{ gap:14px; }

/* ---------- Location ---------- */
.lm-location{ padding:clamp(80px,10vw,130px) var(--lm-gutter); }
.lm-location__grid{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:clamp(34px,4vw,64px);
  align-items:center;
}
.lm-location__chips{ display:flex; flex-wrap:wrap; gap:10px; margin:26px 0 32px; }
.lm-dist-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:var(--lm-white);
  border:1px solid rgba(var(--lm-primary-rgb), .12);
  padding:10px 16px;
  border-radius:var(--lm-radius-pill);
  font-size:13.5px;
  font-weight:600;
  color:var(--lm-ink-soft);
  box-shadow:0 10px 24px -18px rgba(var(--lm-primary-rgb), .5);
}
.lm-location__map{
  position:relative;
  border-radius:24px;
  overflow:hidden;
  height:clamp(320px,38vw,480px);
  box-shadow:var(--lm-shadow-card-lg);
  background:linear-gradient(135deg,#dCEbe6 0%,#cfe4ea 45%,#e7dcc6 100%);
}
.lm-location__map-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(var(--lm-primary-rgb),.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(var(--lm-primary-rgb),.07) 1px, transparent 1px);
  background-size:42px 42px;
}
.lm-location__map-water{
  position:absolute; top:0; bottom:0; left:0;
  width:34%;
  background:linear-gradient(90deg,#bfe0e8,#a9d6e2);
  opacity:.55;
}
.lm-location__map-road{
  position:absolute;
  left:23%; top:-10%;
  width:8%; height:130%;
  background:var(--lm-bg-tan);
  transform:rotate(14deg);
  opacity:.7;
}
.lm-location__pin{
  position:absolute;
  top:50%; left:58%;
  transform:translate(-50%,-100%);
  display:flex;
  flex-direction:column;
  align-items:center;
  text-decoration:none;
}
.lm-location__pin-label{
  background:var(--lm-white);
  color:var(--lm-primary);
  font-weight:700;
  font-size:13px;
  padding:8px 14px;
  border-radius:var(--lm-radius-pill);
  box-shadow:0 12px 26px -10px rgba(var(--lm-primary-rgb), .5);
  white-space:nowrap;
  font-family:var(--lm-font-body);
}
.lm-location__pin-line{ width:2px; height:18px; background:var(--lm-primary); }
.lm-location__pin-dot{
  width:14px; height:14px;
  border-radius:50%;
  background:var(--lm-primary);
  border:3px solid var(--lm-white);
  box-shadow:0 0 0 6px rgba(var(--lm-primary-rgb), .18);
}

/* ---------- Final CTA ---------- */
.lm-cta{
  position:relative;
  padding:clamp(90px,12vw,160px) var(--lm-gutter);
  overflow:hidden;
}
.lm-cta__bg{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  z-index:0;
  background:linear-gradient(180deg,#5b96ab,#2f6175);
}
.lm-cta__overlay{
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(var(--lm-primary-dark-rgb),.55), rgba(var(--lm-primary-dark-rgb),.78));
}
.lm-cta__content{
  position:relative;
  z-index:2;
  max-width:760px;
  margin:0 auto;
  text-align:center;
  color:var(--lm-white);
}
.lm-cta__icon{
  display:inline-flex;
  width:50px; height:50px;
  color:var(--lm-accent);
  margin-bottom:20px;
  animation:lm-float 5s ease-in-out infinite;
  --lm-flower-petal:currentColor;
  --lm-flower-center:var(--lm-white);
}
.lm-cta__title{
  font-family:var(--lm-font-heading);
  font-weight:500;
  font-size:var(--lm-fs-cta-title);
  line-height:1.02;
  margin:0 0 20px;
}
.lm-cta__lead{
  font-size:clamp(16px,2vw,20px);
  color:rgba(var(--lm-white-rgb), .9);
  max-width:520px;
  margin:0 auto 38px;
}
.lm-cta__contacts{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:14px;
  margin-top:40px;
}
.lm-contact-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:rgba(var(--lm-white-rgb), .12);
  border:1px solid rgba(var(--lm-white-rgb), .3);
  color:var(--lm-white);
  padding:12px 22px;
  border-radius:var(--lm-radius-pill);
  text-decoration:none;
  font-weight:600;
  font-size:14px;
  backdrop-filter:blur(6px);
  transition:background var(--lm-dur-fast);
}
.lm-contact-pill:hover{ background:rgba(var(--lm-white-rgb), .22); }

/* ---------- Footer ---------- */
.lm-footer{
  background:var(--lm-navy);
  color:rgba(var(--lm-white-rgb), .7);
  padding:54px var(--lm-gutter) 30px;
}
.lm-footer__top{
  display:flex;
  flex-wrap:wrap;
  justify-content:space-between;
  align-items:center;
  gap:28px;
  border-bottom:1px solid rgba(var(--lm-white-rgb), .12);
  padding-bottom:28px;
}
.lm-footer__brand{ display:flex; align-items:center; gap:12px; }
.lm-footer__logo{
  display:inline-flex;
  width:30px; height:30px;
  --lm-flower-petal:var(--lm-gold);
  --lm-flower-center:var(--lm-primary-light);
}
.lm-footer__brand-name{
  font-family:var(--lm-font-heading);
  font-size:22px;
  color:var(--lm-white);
  font-weight:600;
}
.lm-footer__nav{ display:flex; flex-wrap:wrap; gap:22px; font-size:14px; }
.lm-footer__nav-link{ color:rgba(var(--lm-white-rgb), .7); text-decoration:none; }
.lm-footer__copy{
  max-width:var(--lm-container);
  margin:18px auto 0;
  font-size:12.5px;
  color:rgba(var(--lm-white-rgb), .45);
}

/* ---------- Floating book + contact ---------- */
.lm-float-book{
  position:fixed;
  left:24px; bottom:168px;
  z-index:60;
  background:var(--lm-primary);
  color:var(--lm-white);
  padding:14px 24px;
  border-radius:var(--lm-radius-pill);
  text-decoration:none;
  font-weight:700;
  font-size:14px;
  box-shadow:var(--lm-shadow-btn);
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:background var(--lm-dur-fast);
}
.lm-float-book:hover{ background:var(--lm-primary-light); }

.lm-float-contact{
  position:fixed;
  right:24px; bottom:96px;
  z-index:60;
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:12px;
}
.lm-float-contact__menu{
  display:flex;
  flex-direction:column;
  gap:10px;
  align-items:flex-end;
}
.lm-float-contact__menu[hidden]{ display:none; }
.lm-float-contact__btn{
  width:50px; height:50px;
  border-radius:50%;
  background:var(--lm-primary);
  color:var(--lm-white);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  text-decoration:none;
  box-shadow:0 12px 30px -12px rgba(0,0,0,.5);
  transition:transform .2s;
}
.lm-float-contact__btn:hover{ transform:scale(1.06); }
.lm-float-contact__btn--whatsapp{ background:var(--lm-whatsapp); }
.lm-float-contact__btn--messenger{ background:var(--lm-messenger); }
.lm-float-contact__toggle{
  width:58px; height:58px;
  border-radius:50%;
  border:none;
  background:var(--lm-accent);
  color:var(--lm-ink);
  font-size:24px;
  cursor:pointer;
  box-shadow:0 16px 38px -12px rgba(var(--lm-accent-rgb), .85);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform var(--lm-dur-fast);
}
.lm-float-contact__toggle:hover{ transform:scale(1.06); }

.lm-float-notice{
  position:fixed;
  right:24px; bottom:24px;
  z-index:60;
}
.lm-float-notice__btn{
  width:58px; height:58px;
  border-radius:50%;
  border:none;
  background:#B23A3A;
  color:#fff;
  font-size:26px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  box-shadow:0 16px 38px -12px rgba(178,58,58,.70);
  transition:transform var(--lm-dur-fast), box-shadow var(--lm-dur-fast);
}
.lm-float-notice__btn:hover{ transform:scale(1.06); box-shadow:0 20px 44px -12px rgba(178,58,58,.85); }

/* ---------- Scroll reveal ---------- */
[data-reveal]{
  opacity:0;
  transform:translateY(34px);
  transition:opacity var(--lm-dur-slow) var(--lm-ease), transform var(--lm-dur-slow) var(--lm-ease);
}
[data-reveal].is-visible{
  opacity:1;
  transform:none;
}

/* Bricks builder preview may not run IntersectionObserver; keep content visible there. */
body[data-builder-window] [data-reveal],
body.brx-body:not(.bricks-is-frontend) [data-reveal]{
  opacity:1;
  transform:none;
}

/* ---------- Keyframes ---------- */
@keyframes lm-float{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-16px); } }
@keyframes lm-drift{
  0%{ transform:translateY(0) rotate(0); }
  50%{ transform:translateY(-22px) rotate(18deg); }
  100%{ transform:translateY(0) rotate(0); }
}
@keyframes lm-spin{ from{ transform:rotate(0); } to{ transform:rotate(360deg); } }
@keyframes lm-scrolldot{
  0%{ transform:translateY(0); opacity:0; }
  40%{ opacity:1; }
  100%{ transform:translateY(14px); opacity:0; }
}
@keyframes lm-rise{ from{ opacity:0; transform:translateY(30px); } to{ opacity:1; transform:translateY(0); } }

/* ---------- Responsive ---------- */
@media (max-width: 900px){
  .lm-about__grid,
  .lm-location__grid{ grid-template-columns:1fr; }
  .lm-experience__grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:200px; }
  .lm-exp-card,
  .lm-exp-card--wide{ grid-column:span 2; }
  .lm-offers__grid{ grid-template-columns:1fr; }
  .lm-offer-card{ flex-direction:column; }
  .lm-offer-card__img{ width:100%; height:200px; }
  .lm-header__nav{ display:none; }
}

@media (max-width: 560px){
  .lm-gallery__masonry{ columns:2 160px; }
  .lm-about__list{ grid-template-columns:1fr; }
}
