 .u-section-1 {
  filter: none;
  background-position: 50% 50%, 50% 50%;
  background-repeat: no-repeat, no-repeat;
  background-image: linear-gradient(to bottom, rgba(222, 194, 100, 1), rgba(222, 194, 100, 1)) no-repeat 50% 50% / cover;
  background-size: contain, cover;
  min-height: 892px;
}

.u-section-1 .u-custom-html-1 {
  height: auto;
  min-height: 652px;
  margin: 60px calc(((100% - 1140px) / 2)  + 329px) 60px calc(((100% - 1140px) / 2)  + 484px);
}

@media (max-width: 1199px) {
   .u-section-1 {
    min-height: 0;
  }

  .u-section-1 .u-custom-html-1 {
    margin-right: calc(((100% - 940px) / 2)  + 229px);
    margin-bottom: 0;
    margin-left: calc(((100% - 940px) / 2)  + 384px);
  }
}

@media (max-width: 991px) {
   .u-section-1 {
    background-size: auto 80%, cover;
    min-height: 902px;
  }

  .u-section-1 .u-custom-html-1 {
    margin-right: calc(((100% - 720px) / 2)  + 119px);
    margin-left: calc(((100% - 720px) / 2)  + 274px);
  }
}

@media (max-width: 767px) {
   .u-section-1 {
    min-height: 1104px;
  }

  .u-section-1 .u-custom-html-1 {
    margin-right: calc(((100% - 540px) / 2)  + 29px);
    margin-left: calc(((100% - 540px) / 2)  + 184px);
  }
}

@media (max-width: 575px) {
   .u-section-1 {
    background-size: auto 60%, cover;
  }

  .u-section-1 .u-custom-html-1 {
    margin-right: calc(((100% - 400px) / 2));
    margin-left: calc(((100% - 400px) / 2)  + 73px);
  }
} .u-section-2 {
  padding-left: 163px;
  padding-right: 163px;
  min-height: 165px;
}

.u-section-2 .u-custom-html-1 {
  height: auto;
  margin-top: 0;
  margin-bottom: 53px;
  min-height: 112px;
}

@media (max-width: 991px) {
   .u-section-2 {
    min-height: 156px;
  }

  .u-section-2 .u-custom-html-1 {
    min-height: 101px;
    margin-top: 14px;
    margin-bottom: 41px;
  }
}

@media (max-width: 575px) {
   .u-section-2 {
    padding-left: 0;
    padding-right: 0;
    min-height: 196px;
  }

  .u-section-2 .u-custom-html-1 {
    width: 400px;
    margin: 21px auto 60px;
  }
}/* =========================================================
   Elysian Lustre — Reviews Form (Form + Card styling)
   Extracted from Reviews.css (stable UX + tuned sizing)
   ========================================================= */
/* Outer wrap (gold frame) */
.el-review-wrap{
  background:#d38d00;
  border-radius:16px;
  max-width:1100px;
  margin:0 auto;
  padding:12px 12px;
  box-sizing:border-box;
}
/* Inner card */
.el-review-card{
  background:#fbf6f8;
  border-radius:16px;
  box-shadow:0 10px 26px rgba(0,0,0,.18);
  padding:34px 34px 28px;
}
/* Title + subtitle */
.el-review-title{
  margin:0 0 10px;
  font-size:64px;
  line-height:1.1;
  color:#6b4a5f;
  letter-spacing:.5px;
  text-shadow:7px 7px rgba(91,59,85,.14);
}
.el-review-subtitle{
  margin:0 0 22px;
  font-size:22px;
  color:#5b3b55;
  opacity:.9;
}
/* Layout helpers */
.el-review-form{ display:block; }
.el-field{ margin:16px 0; }
.el-label{
  display:block;
  font-weight:700;
  font-size:24px;
  color:#2b1f28;
  margin:0 0 10px;
}
/* Inputs */
.el-input, .el-select, .el-textarea{
  width:100%;
  box-sizing:border-box;
  border:1px solid rgba(43,31,40,.25);
  border-radius:14px;
  padding:16px 18px;
  font-size:22px;
  background:#fff;
}
.el-textarea{
  min-height:80px;
  resize:vertical;
}
.el-file{ font-size:18px; }
.el-file-note{
  font-size:16px;
  color:rgba(43,31,40,.70);
  margin-top:8px;
}
/* Submit */
.el-actions{
  margin-top:20px;
  display:flex;
  justify-content:center;
}
.el-submit{
  background:#5b3b55;
  color:#fff;
  border:4px solid rgb(245, 197, 66);
  border-radius:999px;
  padding:6px 34px;
  font-size:18px;
  font-weight:800;
  cursor:pointer;
  box-shadow:0 10px 18px rgba(0,0,0,.18);
  transition: transform .12s ease, box-shadow .12s ease;
}
.el-submit:hover{
  transform: translateY(-1px);
  box-shadow:0 14px 22px rgba(0,0,0,.22);
}
.el-submit:disabled{ opacity:.6; cursor:not-allowed; }
/* Alerts */
.el-alert{
  margin-top:16px;
  border-radius:14px;
  padding:14px 16px;
  font-size:18px;
}
.el-alert-success{ background:#d7f5e6; color:#0a5132; }
.el-alert-error{ background:#ffd7d7; color:#7a0b0b; }
/* Custom star buttons (our JS-controlled stars) */
.el-stars{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
}
.el-star{
  width:46px;
  height:46px;
  border-radius:10px;
  border:1px solid rgba(43,31,40,.35);
  background:#fff;
  cursor:pointer;
  font-size:30px;
  line-height:1;
  color:#c9c9c9;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  user-select:none;
  transition: color .12s ease, border-color .12s ease, transform .12s ease, background .12s ease;
}
.el-star:hover{ transform: translateY(-1px); }
.el-star.is-on{ color:#f4a300; }
.el-star:focus{
  outline:3px solid rgba(245,79,165,.35);
  outline-offset:2px;
}
.el-stars-hint{
  margin-left:10px;
  font-size:16px;
  color:rgba(43,31,40,.70);
  min-width:80px;
}
/* Mobile */
@media (max-width: 640px){
  .el-review-card{ padding:22px 18px; }
  .el-review-title{ font-size:46px; }
  .el-label{ font-size:20px; }
  .el-input, .el-select, .el-textarea{ font-size:18px; padding:14px 14px; }
  .el-star{ width:42px; height:42px; font-size:28px; }
}
/* =========================================================
   Review Form Tuning (12 Jan 2026) — tighter Nicepage sizing
   + ensures stars stay clickable/visible as selected
   (keep this AFTER the base styles)
   ========================================================= */
.el-review-card{
  max-width: 520px !important;
  padding: 18px !important;
}
.el-review-title{
  font-size: 48px !important;
  line-height: 1.05 !important;
  margin: 0 0 10px 0 !important;
  color: #6b4a5f !important;
  font-weight: 700 !important;
}
.el-review-subtitle{
  font-size: 15px !important;
  line-height: 1.35 !important;
  margin: 0 0 14px 0 !important;
}
.el-label{
  font-size: 13px !important;
  margin: 10px 0 6px 0 !important;
}
.el-input, .el-select, .el-textarea{
  font-size: 14px !important;
  padding: 10px 12px !important;
  border-radius: 12px !important;
}
.el-textarea{ min-height: 115px !important; }
.el-stars{
  display: inline-flex !important;
  flex-direction: row !important;
  gap: 8px !important;
  align-items: center !important;
  pointer-events: auto !important;
  position: relative !important;
  z-index: 3 !important;
}
.el-star{
  width: 38px !important;
  height: 38px !important;
  border-radius: 10px !important;
  border: 1px solid rgba(60, 45, 55, 0.35) !important;
  background: #fff !important;
  color: #bfbfbf !important;
  font-size: 24px !important;
  line-height: 1 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  user-select: none !important;
  -webkit-tap-highlight-color: transparent !important;
  pointer-events: auto !important;
}
.el-star:hover{
  color: #f4a300 !important;
  border-color: rgba(244, 163, 0, 0.75) !important;
}
.el-star.is-on{
  color: #f4a300 !important;
  border-color: rgba(244, 163, 0, 0.9) !important;
  background: rgba(244, 163, 0, 0.10) !important;
}
.el-star:focus{
  outline: 3px solid rgba(244, 163, 0, 0.35) !important;
  outline-offset: 2px !important;
}
@media (max-width: 640px){
  .el-review-card{ max-width: 92vw !important; }
  .el-review-title{ font-size: 40px !important; }
  .el-star{ width: 42px !important; height: 42px !important; font-size: 26px !important; }
}
/* =========================================================
   Reviews page form positioning + even gold frame (patched)
   - aligns baseline with sample review
   - gold frame hugs the card edges
   ========================================================= */
/* Gold frame container */
.el-review-wrap{
  background:#d38d00;
  border-radius:16px;
  padding:14px !important;          /* even frame thickness */
  display:inline-block !important;  /* hug content */
  width:fit-content !important;
  max-width:none !important;
  box-sizing:border-box !important;
  /* Positioning: keep your left alignment + drop slightly */
  margin-left:auto !important;
  margin-right:0 !important;
  transform:translate(90px, 22px) !important; /* tweak Y if needed */
}
/* Card sizing (locked) */
.el-review-card{
  width:520px !important;
  max-width:520px !important;
  box-sizing:border-box !important;
}
/* Safety: Nicepage wrappers sometimes add odd sizing */
.el-review-wrap *,
.el-review-card *{
  box-sizing:border-box;
}
/* =========================================================
   Elysian Lustre — Recent Reviews Marquee (cards + animation)
   Restored after form-position patch
   ========================================================= */
.el-recent-reviews{
  width: min(1260px, calc(100% - 48px));
  margin: 30px auto;
}
.el-rr-head{ text-align:center; margin-bottom:12px; }
.el-rr-head h3{
  margin:0;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#562C61;
}
.el-rr-sub{ margin-top:6px; font-size:13px; opacity:.7; }
.el-rr-marquee{ position:relative; overflow:hidden; width:100%; }
/* Track-based animation (expects doubled content in the track) */
.el-rr-track{
  display:flex;
  flex-wrap:nowrap;
  gap:18px;
  width:max-content;
  will-change:transform;
  animation: el-rr-scroll var(--rr-duration, 26s) linear infinite;
}
@keyframes el-rr-scroll{
  from{ transform: translateX(0); }
  to{ transform: translateX(-50%); }
}
/* Pause on hover */
.el-rr-marquee:hover .el-rr-track{ animation-play-state: paused; }
/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .el-rr-track{ animation:none; transform:none; }
}
/* Cards */
.el-rr-card{
  width:400px;
  min-width:400px;
  flex: 0 0 400px;
  margin:0 !important; /* prevents replay gap */
  background: rgba(255,255,255,.78);
  border:2px solid rgba(86,44,97,.12);
  border-radius:14px;
  padding:12px 12px 10px;
  box-shadow:0 12px 28px rgba(0,0,0,.10);
}
.el-rr-top{ display:flex; gap:10px; align-items:center; margin-bottom:8px; }
.el-rr-avatar{
  width:30px;
  height:30px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  color:#fff;
  background: linear-gradient(90deg, #562C61 0%, #F54FA5 100%);
}
.el-rr-name{ font-weight:800; line-height:1.1; }
.el-rr-meta{ font-size:12px; opacity:.75; margin-top:2px; }
.el-rr-text{ font-size:15px; line-height:1.45; opacity:.92; }
/* Verified badge (if present in card markup) */
.el-rr-verified{
  display:flex;
  align-items:center;
  gap:6px;
  margin-top:10px;
  font-size:12px;
  font-weight:600;
  color:#3f7a5a;
  opacity:.9;
}
.el-rr-check{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:16px;
  height:16px;
  border-radius:50%;
  background:#3f7a5a;
  color:#fff;
  font-size:11px;
  line-height:1;
}
/* =========================================================
   MARQUEE HARD-FIX: prevent 2-row stacking (rail OR track)
   ========================================================= */
/* Outer viewport */
.el-rr-marquee{
  overflow: hidden !important;
}
/* If JS created a rail wrapper (rail + two tracks), force it horizontal */
.el-rr-marquee .el-rr-rail{
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
  gap: 18px !important;
  width: max-content !important;
}
/* Force BOTH the original track and the cloned track to be horizontal */
.el-rr-marquee .el-rr-track{
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
  gap: 18px !important;
  width: max-content !important;
}
/* Cards must not shrink or wrap */
.el-rr-marquee .el-rr-card{
  width: 400px !important;
  min-width: 400px !important;
  flex: 0 0 400px !important;
}
/* Pause on hover (works for either method) */
.el-rr-marquee:hover .el-rr-track,
.el-rr-marquee:hover .el-rr-rail{
  animation-play-state: paused !important;
}
/* =========================================================
   RESPONSIVE FIXES — Reviews form positioning (Laptop/Tablet/Mobile)
   Desktop untouched.
   ========================================================= */
/* -------------------------------
   Laptop / smaller desktop screens
   (fix: form jammed against right edge)
-------------------------------- */
@media (max-width: 1199px){
  .u-section-1 .u-custom-html-1{
    /* Pull the form left slightly */
    margin-left: auto !important;
    margin-right: 60px !important;
    width: 560px !important;
    max-width: 560px !important;
  }
  /* Prevent the gold wrap from drifting too far right */
  .el-review-wrap{
    transform: translate(0px, 0px) !important;
    margin-left: auto !important;
    margin-right: 0 !important;
  }
}
/* -------------------------------
   Tablet + Mobile view
   Hide model + hearts,
   centre the form,
   keep colourful background,
   start ~40px from top of section
-------------------------------- */
@media (max-width: 991px){
  /* Hide model + decorative layers */
  .u-section-1 .u-group-2,
  .u-section-1 .u-image-2,
  .u-section-1 .u-image-3,
  .u-section-1 .u-image-4,
  .u-section-1 .u-image-5{
    display: none !important;
  }
  /* Let the background section breathe */
  .u-section-1{
    min-height: auto !important;
  }
  /* Ensure the colourful BG container stays visible */
  .u-section-1 .u-image-1{
    min-height: auto !important;
    margin-top: 0 !important;
    padding-top: 40px !important; /* <-- requested 40px top */
    padding-bottom: 60px !important;
  }
  /* Centre the HTML5 block that contains the form */
  .u-section-1 .u-custom-html-1{
    margin: 0 auto !important;
    width: 100% !important;
    max-width: 560px !important;
    min-height: auto !important;
  }
  /* Centre the gold wrap + remove hard transforms */
  .el-review-wrap{
    transform: none !important;
    margin: 0 auto !important;
    max-width: 560px !important;
  }
  /* Keep the card responsive */
  .el-review-card{
    width: 100% !important;
    max-width: 560px !important;
  }
}
/* Mobile narrower fitting */
@media (max-width: 575px){
  .u-section-1 .u-image-1{
    padding-top: 40px !important;
    padding-bottom: 50px !important;
  }
  .u-section-1 .u-custom-html-1{
    max-width: 92vw !important;
  }
  .el-review-wrap{
    max-width: 92vw !important;
  }
  .el-review-card{
    max-width: 92vw !important;
  }
}
/* =========================================================
   REVIEWS FORM — fit card within viewport (Desktop/Laptop/Tablet)
   + reduce gold frame thickness
   ========================================================= */
/* ---- Gold frame thickness (all views) ---- */
.el-review-wrap{
  padding: 8px !important;          /* was ~14px; thinner luxury frame */
  border-radius: 16px !important;
}
/* ---- Desktop: make the whole card fit on screen ---- */
@media (min-width: 1200px){
  .el-review-card{
    /* Keep it visually the same, but shorter */
    padding: 16px !important;
    max-height: calc(100vh - 170px) !important; /* accounts for header + breathing room */
    overflow: hidden !important;                /* prevents internal scrollbars */
  }
  .el-review-title{
    font-size: 40px !important;
    margin: 0 0 6px 0 !important;
  }
  .el-review-subtitle{
    font-size: 14px !important;
    margin: 0 0 10px 0 !important;
  }
  .el-field{ margin: 10px 0 !important; }
  .el-label{ font-size: 13px !important; margin: 8px 0 5px 0 !important; }
  .el-input, .el-select, .el-textarea{
    padding: 9px 11px !important;
    font-size: 14px !important;
  }
  .el-textarea{
    min-height: 95px !important;   /* shorter so card fits */
  }
  .el-actions{ margin-top: 12px !important; }
}
/* ---- Laptop: same mindset, slightly narrower viewport ---- */
@media (min-width: 992px) and (max-width: 1199px){
  .el-review-wrap{ padding: 8px !important; }
  .el-review-card{
    padding: 15px !important;
    max-height: calc(100vh - 165px) !important;
    overflow: hidden !important;
  }
  .el-review-title{ font-size: 38px !important; }
  .el-review-subtitle{ font-size: 14px !important; margin-bottom: 10px !important; }
  .el-field{ margin: 10px 0 !important; }
  .el-label{ font-size: 13px !important; }
  .el-input, .el-select, .el-textarea{
    padding: 9px 11px !important;
    font-size: 14px !important;
  }
  .el-textarea{ min-height: 90px !important; }
  .el-actions{ margin-top: 12px !important; }
}
/* =========================================================
   TABLET ONLY (iPad-ish): drop + shift form card
   ========================================================= */
@media (min-width: 768px) and (max-width: 991px){
  /* Move the whole form block */
  .u-section-1 .u-custom-html-1{
    margin-top: 20px !important;     /* drop ~20px */
    margin-left: auto !important;
    margin-right: 0 !important;      /* push right */
    max-width: 560px !important;
    width: 560px !important;
  }
  .u-section-1{
  padding-bottom: 70px !important;
    
  /* If your form wrap still has transforms from desktop rules, neutralise then nudge */
  .el-review-wrap{
    transform: translate(40px, 20px) !important;  /* right + down */
    margin-right: 12px !important;               /* little breathing room */
  }
}
/* =========================================================
   MARQUEE — make it as wide as can be (full viewport)
   ========================================================= */
.el-recent-reviews{
  width: 100vw !important;
  max-width: 100vw !important;
  margin-left: calc(50% - 50vw) !important;  /* breaks out of Nicepage container */
  margin-right: calc(50% - 50vw) !important;
}
.el-rr-marquee{
  width: 100% !important;
  max-width: 100% !important;
}
/* ================================
   MOBILE REVIEW CARD SCALING
   ================================ */
@media (max-width: 767px) {
  /* Card container */
  .el-review-card {
    max-width: 92vw;              /* responsive width */
    margin: 32px auto 40px;       /* breathing room top/bottom */
    padding: 18px 16px 20px;
    border-width: 6px;            /* thinner gold frame */
    border-radius: 20px;
  }
  /* Title */
  .el-review-card h2,
  .el-review-card h3 {
    font-size: 22px;
    line-height: 1.2;
    margin-bottom: 8px;
  }
  /* Subtitle / helper text */
  .el-review-card p,
  .el-review-card .el-review-sub {
    font-size: 14px;
    line-height: 1.4;
  }
  /* Labels */
  .el-review-card label {
    font-size: 14px;
    margin-bottom: 4px;
  }
  /* Inputs + selects + textarea */
  .el-review-card input,
  .el-review-card select,
  .el-review-card textarea {
    font-size: 15px;
    padding: 10px 12px;
    border-radius: 12px;
  }
  /* Textarea height */
  .el-review-card textarea {
    min-height: 90px;
  }
  /* Star rating */
  .el-star {
    width: 34px;
    height: 34px;
  }
  /* Submit button */
  .el-review-card button[type="submit"] {
    font-size: 15px;
    padding: 12px 24px;
    border-radius: 999px;
    margin-top: 12px;
  }
} 