.elementor-144 .elementor-element.elementor-element-ada2f95{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-144 .elementor-element.elementor-element-47690b1{width:100%;max-width:100%;margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-144 .elementor-element.elementor-element-db2e09d{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-144 .elementor-element.elementor-element-77b3b6f{width:100%;max-width:100%;margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-144 .elementor-element.elementor-element-c1a6fb4{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-144 .elementor-element.elementor-element-9d34797{width:100%;max-width:100%;margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-144 .elementor-element.elementor-element-cce0352{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-144 .elementor-element.elementor-element-0f9ee00{--display:flex;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-144 .elementor-element.elementor-element-869fc28{width:100%;max-width:100%;margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-144 .elementor-element.elementor-element-ce6c694{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-144 .elementor-element.elementor-element-5e015f1{width:100%;max-width:100%;margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}.elementor-144 .elementor-element.elementor-element-0a56839{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;--margin-top:0px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-144 .elementor-element.elementor-element-a3e2b0b{width:100%;max-width:100%;margin:0px 0px calc(var(--kit-widget-spacing, 0px) + 0px) 0px;padding:0px 0px 0px 0px;}@media(min-width:768px){.elementor-144 .elementor-element.elementor-element-ce6c694{--content-width:100%;}}/* Start custom CSS for html, class: .elementor-element-47690b1 *//* ===== Our Catering Services (Unique / No conflicts) ===== */
.acsv-hero{
  --acsv-bg1:#0f3c34;
  --acsv-bg2:#0b2f28;
  --acsv-cream: rgba(255,255,255,.92);
  --acsv-cream80: rgba(255,255,255,.78);
  --acsv-gold:#c79a63;

  position: relative;
  width: 100%;
  padding: clamp(64px, 7vw, 110px) 0 clamp(44px, 5vw, 70px);
  overflow: hidden;

  background: radial-gradient(900px 420px at 50% 30%, rgba(255,255,255,.05), transparent 60%),
              linear-gradient(180deg, var(--acsv-bg1), var(--acsv-bg2));

  margin-top: 0 !important;
  border-top: 0 !important;
}

.acsv-wrap{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 20px;
}

.acsv-head{
  text-align: center;
  max-width: 860px;
  margin: 0 auto;
}

/* ===== divider: line starts from star (left + right) ===== */
.acsv-divider{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-bottom: 18px;
}

.acsv-star{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width: 28px;
  height: 28px;
  color: var(--acsv-gold) !important;
  font-size: 20px;
  line-height: 1;
  transform: translateY(-1px);
}

/* the two lines */
.acsv-line{
  height: 1px;
  width: clamp(140px, 22vw, 420px);
  background: linear-gradient(90deg, transparent, rgba(199,154,99,.40));
  opacity: .95;
}

.acsv-line--l{
  background: linear-gradient(90deg, transparent, rgba(199,154,99,.40));
}

.acsv-line--r{
  background: linear-gradient(90deg, rgba(199,154,99,.40), transparent);
}

/* title */
.acsv-title{
  margin: 0 0 18px 0 !important;
  color: var(--acsv-cream) !important;
  font-family: "Playfair Display", serif;
  font-weight: 700;
  letter-spacing: .2px;
  line-height: 1.02;
  font-size: clamp(38px, 4.8vw, 72px);
  text-shadow: 0 18px 46px rgba(0,0,0,.28);
}

.acsv-gold{ color: var(--acsv-gold) !important; }

/* subtitle */
.acsv-subtitle{
  margin: 0 !important;
  color: var(--acsv-cream80) !important;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  font-weight: 500;
  font-size: clamp(14px, 1.35vw, 18px);
  line-height: 1.7;
  text-shadow: 0 14px 34px rgba(0,0,0,.22);
}

/* ===== Page-open animation (small delay) ===== */
@keyframes acsvFadeUp {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

.acsv-divider,
.acsv-title,
.acsv-subtitle{
  opacity: 0;
  animation: acsvFadeUp .85s ease forwards;
  will-change: opacity, transform;
}

.acsv-divider{  animation-delay: .10s; }
.acsv-title{    animation-delay: .22s; }
.acsv-subtitle{ animation-delay: .36s; }

@media (prefers-reduced-motion: reduce){
  .acsv-divider,
  .acsv-title,
  .acsv-subtitle{
    opacity: 1 !important;
    animation: none !important;
    transform: none !important;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-77b3b6f *//* ====== CORE COLORS ====== */
.as-story{
  --cream:#f7f2ea;
  --paper:#fbf7f1;
  --ink:#143b33;
  --muted:rgba(20,59,51,.78);
  --maroon:#7b2d37;
  --gold:#caa56a;
  --gold2:#e2c48f;

  position:relative;
  padding: clamp(54px, 6vw, 92px) 0;
  background:
    radial-gradient(900px 420px at 20% 0%, rgba(202,165,106,.10), transparent 55%),
    radial-gradient(900px 420px at 80% 10%, rgba(123,45,55,.08), transparent 60%),
    linear-gradient(180deg, var(--paper), var(--cream));
  overflow:hidden;
  isolation:isolate;

  color: var(--ink) !important; /* Astra override */
}
.as-story *{ color: inherit; }
.as-story a, .as-story a:visited, .as-story a:hover{ color: inherit !important; text-decoration:none !important; }

.as-wrap{ max-width:1180px; margin:0 auto; padding:0 18px; }

/* ====== LAYOUT ====== */
.as-grid{
  display:grid;
  grid-template-columns: 1.05fr .95fr;
  gap: clamp(22px, 4vw, 56px);
  align-items:center;
}

/* ====== LEFT SIDE: WRAPPER (NO CLIPPING) ====== */
.as-mediaWrap{
  position: relative;
  /* THIS is important: allow badge to go outside */
  overflow: visible;
}

/* figure only clips the IMAGE corners */
.as-media{
  margin:0;
  border-radius: 18px;
  overflow: hidden;            /* keep rounded corners for image */
  box-shadow: 0 22px 60px rgba(0,0,0,.12);
  position: relative;

  /* IMAGE comes from LEFT */
  opacity:0;
  transform: translateX(-40px);
  animation: as-inLeft .95s cubic-bezier(.2,.9,.2,1) both;
}
@keyframes as-inLeft{
  to{ opacity:1; transform: translateX(0); }
}

.as-img{
  display:block;
  width:100%;
  height: 420px;
  object-fit: cover;
  transform: scale(1.02);
  transition: transform .9s ease;
}
.as-media:hover .as-img{ transform: scale(1.08); }

/* ====== BADGE: POPS OUT ====== */
.as-badge{
  position:absolute;
  right: 18px;
  bottom: -22px;               /* pop OUTSIDE image */
  background: var(--maroon);
  color: #fff !important;
  padding: 18px 18px;
  border-radius: 14px;
  width: min(280px, 78%);
  box-shadow: 0 22px 55px rgba(0,0,0,.22);
  border: 1px solid rgba(226,196,143,.35);
  z-index: 5;

  /* POP animation */
  opacity:0;
  transform: translateY(18px) scale(.94);
  animation: as-popBadge .8s cubic-bezier(.2,1.2,.2,1) both, as-float 5.2s ease-in-out infinite;
  animation-delay: .55s, 1.35s;
}
@keyframes as-popBadge{
  0%{ opacity:0; transform: translateY(18px) scale(.94); }
  65%{ opacity:1; transform: translateY(0) scale(1.05); }
  100%{ opacity:1; transform: translateY(0) scale(1); }
}
@keyframes as-float{
  0%,100%{ transform: translateY(0) scale(1); }
  50%{ transform: translateY(-6px) scale(1); }
}

.as-badge-num{
  font-family:"Playfair Display", ui-serif, Georgia, serif;
  font-weight:800;
  font-size:30px;
  line-height:1;
  color: var(--gold2) !important;
}
.as-badge-txt{
  margin-top:6px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  font-size:13px;
  opacity:.95;
}

/* ====== RIGHT SIDE: CONTENT comes from RIGHT ====== */
.as-content{
  opacity:0;
  transform: translateX(40px);
  animation: as-inRight .95s cubic-bezier(.2,.9,.2,1) both;
  animation-delay: .15s;
}
@keyframes as-inRight{
  to{ opacity:1; transform: translateX(0); }
}

.as-title{
  margin:0 0 14px;
  font-family:"Playfair Display", ui-serif, Georgia, serif;
  font-weight:800;
  font-size: clamp(32px, 3.1vw, 54px);
  line-height:1.05;
  color: var(--ink) !important;
}
.as-maroon{ color: var(--maroon) !important; }

.as-copy{
  margin-top:18px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color: var(--muted) !important;
  line-height:1.85;
  font-size:14.5px;
}
.as-copy p{
  margin:0 0 14px;
  opacity:0;
  transform: translateY(10px);
  animation: as-para .75s ease both;
}
.as-copy p:nth-child(1){ animation-delay: .40s; }
.as-copy p:nth-child(2){ animation-delay: .52s; }
.as-copy p:nth-child(3){ animation-delay: .64s; }
@keyframes as-para{ to{ opacity:1; transform: translateY(0); } }

/* ====== STATS ====== */
.as-stats{
  margin-top: clamp(44px, 4.2vw, 70px); /* more space because badge pops down */
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}
.as-card{
  background:#fff;
  border: 1px solid rgba(202,165,106,.28);
  border-radius: 12px;
  padding: 22px 16px;
  text-align:center;
  box-shadow: 0 18px 40px rgba(0,0,0,.06);

  opacity:0;
  transform: translateY(12px);
  animation: as-rise .85s cubic-bezier(.2,.9,.2,1) both;
}
.as-card:nth-child(1){ animation-delay: .75s; }
.as-card:nth-child(2){ animation-delay: .87s; }
.as-card:nth-child(3){ animation-delay: .99s; }
.as-card:nth-child(4){ animation-delay: 1.11s; }

@keyframes as-rise{ to{ opacity:1; transform: translateY(0); } }

.as-big{
  font-family:"Playfair Display", ui-serif, Georgia, serif;
  font-weight:800;
  font-size: clamp(28px, 2.3vw, 40px);
  color: var(--maroon) !important;
}
.as-small{
  margin-top:8px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  font-size:12px;
  color: rgba(20,59,51,.70) !important;
}

/* hover */
.as-card{
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
}
.as-card:hover{
  transform: translateY(-6px);
  box-shadow: 0 26px 55px rgba(0,0,0,.10);
  border-color: rgba(202,165,106,.55);
}

/* ====== RESPONSIVE ====== */
@media (max-width: 980px){
  .as-grid{ grid-template-columns: 1fr; }
  .as-img{ height: 360px; }
  .as-badge{ right: 14px; bottom: -18px; }
  .as-stats{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 520px){
  .as-img{ height: 300px; }
  .as-badge{ width: 82%; right: 10px; }
  .as-stats{ grid-template-columns: 1fr; }
}

/* ====== REDUCED MOTION ====== */
@media (prefers-reduced-motion: reduce){
  .as-media,.as-content,.as-badge,.as-copy p,.as-card{
    animation:none !important;
    opacity:1 !important;
    transform:none !important;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-9d34797 *//* Paste into Elementor > Advanced > Custom CSS (or Site CSS) */

.wt-section{
  --green1:#0f3a2f;
  --green2:#0b2f26;
  --cream:#f6efe6;
  --cream70: rgba(246,239,230,.72);
  --gold:#caa56a;
  --gold2:#e2c48f;

  position:relative;
  padding: clamp(60px, 6vw, 96px) 0;
  color: var(--cream) !important;
  overflow:hidden;
  isolation:isolate;

  background:
    radial-gradient(1200px 520px at 50% -12%, rgba(255,255,255,.10), transparent 55%),
    radial-gradient(900px 520px at 10% 20%, rgba(202,165,106,.12), transparent 55%),
    radial-gradient(900px 520px at 90% 30%, rgba(202,165,106,.08), transparent 60%),
    linear-gradient(180deg, var(--green1), var(--green2));
}

/* Astra blue override safety */
.wt-section *{ color: inherit; }
.wt-section a, .wt-section a:visited, .wt-section a:hover{ color: inherit !important; text-decoration:none !important; }

/* animated “mughal” pattern */
.wt-section::before{
  content:"";
  position:absolute; inset:-35%;
  background:
    radial-gradient(circle at 18% 24%, rgba(202,165,106,.14) 0 1.2px, transparent 2px),
    radial-gradient(circle at 70% 18%, rgba(202,165,106,.10) 0 1.2px, transparent 2px),
    radial-gradient(circle at 40% 78%, rgba(202,165,106,.10) 0 1.1px, transparent 2px),
    linear-gradient(45deg, rgba(255,255,255,.055) 0 1px, transparent 1px 26px);
  background-size: 150px 150px, 200px 200px, 230px 230px, 26px 26px;
  opacity:.35;
  transform: rotate(7deg);
  animation: wt-pattern 14s ease-in-out infinite;
  z-index:-2;
}
@keyframes wt-pattern{
  0%,100%{ transform: translate3d(-1%, -1%, 0) rotate(7deg); }
  50%{ transform: translate3d(1.1%, .9%, 0) rotate(7deg); }
}

.wt-section::after{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(900px 520px at 50% 40%, transparent 28%, rgba(0,0,0,.20) 72%);
  z-index:-1;
}

.wt-wrap{
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 18px;
}

/* ===== Header ===== */
.wt-head{
  text-align:center;
  margin-bottom: clamp(36px, 4vw, 62px);
  opacity:0;
  transform: translateY(14px);
  animation: wt-fadeUp .9s ease both;
}
@keyframes wt-fadeUp{ to{ opacity:1; transform: translateY(0);} }

.wt-divider{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  margin-bottom: 14px;
}

.wt-line{
  width: min(240px, 28vw);
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(202,165,106,.60), transparent);
  transform: scaleX(.25);
  transform-origin:center;
  opacity:.2;
  animation: wt-line 1.1s ease .2s both;
}
@keyframes wt-line{ to{ transform: scaleX(1); opacity:1; } }

.wt-spark{
  color: var(--gold) !important;
  font-size: 20px;
  filter: drop-shadow(0 10px 16px rgba(202,165,106,.20));
  animation: wt-sparkle 2.6s ease-in-out infinite;
}
@keyframes wt-sparkle{
  0%,100%{ transform: translateY(0) rotate(0deg); opacity:.9; }
  50%{ transform: translateY(-3px) rotate(6deg); opacity:1; }
}

.wt-title{
  margin:0 0 10px;
  font-family: "Playfair Display", ui-serif, Georgia, serif;
  font-weight: 800;
  font-size: clamp(32px, 3.6vw, 56px);
  line-height: 1.05;
  text-shadow: 0 18px 40px rgba(0,0,0,.30);
}
.wt-gold{ color: var(--gold) !important; position:relative; }

/* shimmer on “Trust Aleena” */
.wt-gold::after{
  content:"";
  position:absolute; inset:-6px -10px;
  background: linear-gradient(115deg, transparent 0 38%, rgba(255,255,255,.22) 50%, transparent 62% 100%);
  transform: translateX(-60%);
  opacity:0;
  animation: wt-shimmer 3.8s ease-in-out infinite;
  pointer-events:none;
}
@keyframes wt-shimmer{
  0%{ transform: translateX(-60%); opacity:0; }
  20%{ opacity:.55; }
  45%{ transform: translateX(60%); opacity:0; }
  100%{ opacity:0; }
}

.wt-sub{
  margin:0 auto;
  max-width: 620px;
  color: var(--cream70) !important;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  font-size: 15px;
}

/* ===== Grid ===== */
.wt-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.wt-card{
  position:relative;
  display:flex;
  gap: 16px;
  padding: 22px;
  border-radius: 14px;
  background: rgba(246,239,230,.06);
  border: 1px solid rgba(202,165,106,.22);
  backdrop-filter: blur(6px);
  box-shadow: 0 18px 40px rgba(0,0,0,.18);
  overflow:hidden;

  /* entrance stagger */
  opacity:0;
  transform: translateY(18px);
  animation: wt-cardIn .85s cubic-bezier(.2,.9,.2,1) both;
  animation-delay: calc(.22s + (var(--i) * .10s));
}
@keyframes wt-cardIn{ to{ opacity:1; transform: translateY(0);} }

/* animated border glow */
.wt-card::before{
  content:"";
  position:absolute; inset:-2px;
  border-radius: 14px;
  background: conic-gradient(from 180deg, rgba(202,165,106,.0), rgba(202,165,106,.40), rgba(202,165,106,.0));
  opacity:.0;
  filter: blur(10px);
  transition: opacity .35s ease;
  pointer-events:none;
}
.wt-card::after{
  /* moving highlight */
  content:"";
  position:absolute; inset:-40%;
  background: linear-gradient(115deg, transparent 0 42%, rgba(202,165,106,.16) 50%, transparent 60% 100%);
  transform: translateX(-55%);
  opacity:0;
  animation: wt-sheen 5.2s ease-in-out infinite;
  pointer-events:none;
}
@keyframes wt-sheen{
  0%{ transform: translateX(-55%); opacity:0; }
  16%{ opacity:.7; }
  40%{ transform: translateX(55%); opacity:0; }
  100%{ opacity:0; }
}

/* icon */
.wt-ico{
  width: 54px;
  height: 54px;
  color: var(--gold) !important;
  flex: 0 0 auto;
  display:grid;
  place-items:center;
  border-radius: 999px;
  background: rgba(246,239,230,.06);
  border: 1px solid rgba(202,165,106,.26);
  position: relative;
  overflow:hidden;
  transform: translateY(2px);
}

/* icon pulse ring */
.wt-ico::before{
  content:"";
  position:absolute; inset:-40%;
  background: radial-gradient(circle at 30% 30%, rgba(226,196,143,.25), transparent 60%);
  opacity:.85;
  animation: wt-icoGlow 3.8s ease-in-out infinite;
}
@keyframes wt-icoGlow{
  0%,100%{ transform: scale(1); opacity:.7; }
  50%{ transform: scale(1.15); opacity:1; }
}

.wt-ico svg{
  width: 34px;
  height: 34px;
  position: relative;
  z-index: 1;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;

  animation: wt-iconFloat 4.6s ease-in-out infinite;
  animation-delay: calc(.6s + (var(--i) * .12s));
}
@keyframes wt-iconFloat{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-4px); }
}
.wt-fill{ fill: currentColor; stroke: none; }
.wt-strong{ stroke-width: 3; }

/* text */
.wt-h3{
  margin: 2px 0 8px;
  font-family: "Playfair Display", ui-serif, Georgia, serif;
  font-weight: 800;
  font-size: 18px;
  color: var(--cream) !important;
}
.wt-p{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color: rgba(246,239,230,.72) !important;
  font-size: 13px;
  line-height: 1.65;
  max-width: 42ch;
}

/* Hover interactions (premium) */
.wt-card{
  transition: transform .35s ease, border-color .35s ease, background .35s ease, box-shadow .35s ease;
}
.wt-card:hover{
  transform: translateY(-8px);
  border-color: rgba(202,165,106,.45);
  background: rgba(246,239,230,.10);
  box-shadow: 0 26px 60px rgba(0,0,0,.24);
}
.wt-card:hover::before{ opacity: 1; }
.wt-card:hover .wt-ico svg{
  animation: wt-wiggle .7s ease both;
}
@keyframes wt-wiggle{
  0%{ transform: rotate(0deg) }
  25%{ transform: rotate(-7deg) scale(1.05) }
  50%{ transform: rotate(7deg) scale(1.05) }
  100%{ transform: rotate(0deg) }
}

/* ===== Responsive ===== */
@media (max-width: 980px){
  .wt-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px){
  .wt-grid{ grid-template-columns: 1fr; }
  .wt-card{ padding: 18px; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .wt-section::before,
  .wt-head,
  .wt-line,
  .wt-spark,
  .wt-gold::after,
  .wt-card,
  .wt-card::after,
  .wt-ico::before,
  .wt-ico svg{
    animation:none !important;
    transition:none !important;
    opacity:1 !important;
    transform:none !important;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-869fc28 *//* Testimonials Section (scoped) */
.ts-section{
  --paper:#fbf7f1;
  --cream:#f6efe6;
  --ink:#143b33;       /* deep green */
  --maroon:#7b2d37;
  --gold:#caa56a;
  --gold2:#e2c48f;

  position:relative;
  padding: clamp(64px, 6vw, 98px) 0;
  background:
    radial-gradient(1200px 520px at 50% -10%, rgba(20,59,51,.08), transparent 55%),
    radial-gradient(900px 520px at 12% 22%, rgba(202,165,106,.13), transparent 58%),
    radial-gradient(900px 520px at 90% 35%, rgba(123,45,55,.10), transparent 62%),
    linear-gradient(180deg, var(--paper), var(--cream));
  overflow:hidden;
  isolation:isolate;
  color: var(--ink) !important;
}

/* Astra override safety */
.ts-section, .ts-section *{ color: inherit; }
.ts-section a, .ts-section a:visited, .ts-section a:hover{ color: inherit !important; text-decoration:none !important; }

.ts-section::before{
  content:"";
  position:absolute; inset:-35%;
  background:
    radial-gradient(circle at 18% 24%, rgba(202,165,106,.14) 0 1.2px, transparent 2px),
    radial-gradient(circle at 70% 18%, rgba(123,45,55,.09) 0 1.2px, transparent 2px),
    radial-gradient(circle at 40% 78%, rgba(202,165,106,.10) 0 1.1px, transparent 2px),
    linear-gradient(45deg, rgba(20,59,51,.05) 0 1px, transparent 1px 26px);
  background-size: 150px 150px, 200px 200px, 230px 230px, 26px 26px;
  opacity:.35;
  transform: rotate(7deg);
  animation: ts-pattern 14s ease-in-out infinite;
  z-index:-2;
}
@keyframes ts-pattern{
  0%,100%{ transform: translate3d(-1%, -1%, 0) rotate(7deg); }
  50%{ transform: translate3d(1.1%, .9%, 0) rotate(7deg); }
}

.ts-wrap{
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 18px;
}

/* Header */
.ts-head{ text-align:center; margin-bottom: clamp(34px, 4vw, 60px); }
.ts-divider{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  margin-bottom: 14px;
}
.ts-line{
  width: min(260px, 30vw);
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(202,165,106,.60), transparent);
  transform: scaleX(.15);
  opacity:.25;
}
.ts-spark{
  color: var(--gold) !important;
  font-size: 20px;
  filter: drop-shadow(0 12px 18px rgba(202,165,106,.20));
  animation: ts-spark 2.8s ease-in-out infinite;
}
@keyframes ts-spark{
  0%,100%{ transform: translateY(0) rotate(0deg); opacity:.9; }
  50%{ transform: translateY(-3px) rotate(7deg); opacity:1; }
}

.ts-title{
  margin:0 0 10px;
  font-family: "Playfair Display", ui-serif, Georgia, serif;
  font-weight: 800;
  font-size: clamp(32px, 3.6vw, 56px);
  line-height: 1.05;
  letter-spacing: .2px;
}
.ts-accent{
  color: var(--maroon) !important;
  position:relative;
}
.ts-accent::after{
  content:"";
  position:absolute; inset:-7px -10px;
  background: linear-gradient(115deg, transparent 0 38%, rgba(255,255,255,.25) 50%, transparent 62% 100%);
  transform: translateX(-60%);
  opacity:0;
  animation: ts-shimmer 3.9s ease-in-out infinite;
  pointer-events:none;
}
@keyframes ts-shimmer{
  0%{ transform: translateX(-60%); opacity:0; }
  20%{ opacity:.6; }
  45%{ transform: translateX(60%); opacity:0; }
  100%{ opacity:0; }
}

.ts-sub{
  margin:0 auto;
  max-width: 640px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color: rgba(20,59,51,.72) !important;
  font-size: 14.5px;
}

/* Grid */
.ts-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

/* Card */
.ts-card{
  position:relative;
  border-radius: 12px;
  padding: 20px 18px 18px;
  background: rgba(255,255,255,.62);
  border: 1px solid rgba(202,165,106,.28);
  box-shadow: 0 18px 40px rgba(0,0,0,.06);
  overflow:hidden;
  backdrop-filter: blur(6px);
  transform-style: preserve-3d;
  transition: transform .38s ease, box-shadow .38s ease, border-color .38s ease, background .38s ease;
}

/* top highlight bar like your screenshot */
.ts-card::before{
  content:"";
  position:absolute; left:0; top:0; right:0;
  height: 3px;
  background: linear-gradient(90deg, rgba(202,165,106,.65), rgba(123,45,55,.55));
  opacity:.85;
}

/* moving sheen */
.ts-card::after{
  content:"";
  position:absolute; inset:-40%;
  background: linear-gradient(115deg, transparent 0 42%, rgba(202,165,106,.16) 50%, transparent 60% 100%);
  transform: translateX(-55%);
  opacity:0;
  animation: ts-sheen 5.4s ease-in-out infinite;
  pointer-events:none;
}
@keyframes ts-sheen{
  0%{ transform: translateX(-55%); opacity:0; }
  18%{ opacity:.75; }
  42%{ transform: translateX(55%); opacity:0; }
  100%{ opacity:0; }
}

/* Quote mark */
.ts-quote{
  position:absolute;
  top: 14px;
  right: 14px;
  font-size: 44px;
  line-height: 1;
  color: rgba(202,165,106,.18) !important;
  font-family: ui-serif, Georgia, serif;
  transform: translateZ(12px);
  animation: ts-float 4.6s ease-in-out infinite;
}
@keyframes ts-float{
  0%,100%{ transform: translateY(0) translateZ(12px); }
  50%{ transform: translateY(-6px) translateZ(12px); }
}

/* Stars */
.ts-stars{
  display:flex;
  gap: 4px;
  margin: 6px 0 12px;
}
.ts-star{
  color: var(--gold) !important;
  font-size: 14px;
  filter: drop-shadow(0 10px 14px rgba(202,165,106,.12));
  animation: ts-twinkle 2.8s ease-in-out infinite;
}
.ts-star:nth-child(2){ animation-delay: .12s; }
.ts-star:nth-child(3){ animation-delay: .24s; }
.ts-star:nth-child(4){ animation-delay: .36s; }
.ts-star:nth-child(5){ animation-delay: .48s; }

@keyframes ts-twinkle{
  0%,100%{ transform: translateY(0); opacity:.95; }
  50%{ transform: translateY(-2px); opacity:1; }
}

/* Text */
.ts-text{
  margin: 0 0 14px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  font-size: 13px;
  line-height: 1.75;
  color: rgba(20,59,51,.82) !important;
}

/* Footer */
.ts-footer{
  border-top: 1px solid rgba(202,165,106,.22);
  padding-top: 12px;
}
.ts-name{
  font-family: "Playfair Display", ui-serif, Georgia, serif;
  font-weight: 800;
  font-size: 15px;
  color: var(--ink) !important;
}
.ts-loc{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  font-size: 11.5px;
  color: rgba(20,59,51,.68) !important;
  margin-top: 2px;
}
.ts-tag{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  font-size: 11.5px;
  color: var(--gold) !important;
  margin-top: 6px;
}

/* Hover = premium lift + tilt */
.ts-card:hover{
  transform: translateY(-10px) rotateX(2deg);
  border-color: rgba(202,165,106,.55);
  background: rgba(255,255,255,.72);
  box-shadow: 0 28px 70px rgba(0,0,0,.10);
}

/* ===== Scroll Reveal (works with JS below) ===== */
.ts-reveal{
  opacity: 0;
  transform: translateY(26px);
  filter: blur(5px);
  transition: opacity .8s cubic-bezier(.2,.9,.2,1),
              transform .8s cubic-bezier(.2,.9,.2,1),
              filter .8s cubic-bezier(.2,.9,.2,1);
  will-change: opacity, transform, filter;
}
.ts-reveal.ts-in{
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

/* Animate divider lines when in view */
.ts-head.ts-in .ts-line{
  transform: scaleX(1);
  opacity: 1;
  transition: transform 1.1s ease .15s, opacity .8s ease .15s;
}

/* Stagger helper */
.ts-reveal{ transition-delay: var(--delay, 0ms); }

/* Responsive */
@media (max-width: 1024px){
  .ts-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 560px){
  .ts-grid{ grid-template-columns: 1fr; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .ts-section::before,
  .ts-spark,
  .ts-accent::after,
  .ts-card::after,
  .ts-quote,
  .ts-star{
    animation:none !important;
  }
  .ts-reveal{
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
    transition:none !important;
  }
}
.cta-btn--gold .cta-btn__arrow{
  color: #000 !important;
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-5e015f1 *//* CITIES SECTION (paste in Elementor Custom CSS / Site CSS) */

.cs-section{
  --maroon1:#6b222c;
  --maroon2:#3f151b;
  --cream:#f6efe6;
  --cream70: rgba(246,239,230,.72);
  --gold:#caa56a;
  --gold2:#e2c48f;

  position:relative;
  padding: clamp(58px, 6vw, 92px) 0;
  color: var(--cream) !important;
  overflow:hidden;
  isolation:isolate;

  background:
    radial-gradient(1000px 420px at 50% -12%, rgba(255,255,255,.09), transparent 55%),
    radial-gradient(900px 520px at 10% 25%, rgba(202,165,106,.13), transparent 60%),
    radial-gradient(900px 520px at 90% 35%, rgba(202,165,106,.10), transparent 62%),
    linear-gradient(180deg, var(--maroon1), var(--maroon2));
}

/* Astra theme color override safety */
.cs-section, .cs-section *{ color: inherit; }
.cs-section a, .cs-section a:visited, .cs-section a:hover{ color: inherit !important; text-decoration:none !important; }

.cs-section::before{
  /* premium moving pattern */
  content:"";
  position:absolute; inset:-35%;
  background:
    radial-gradient(circle at 18% 24%, rgba(202,165,106,.18) 0 1.2px, transparent 2px),
    radial-gradient(circle at 72% 18%, rgba(202,165,106,.12) 0 1.2px, transparent 2px),
    radial-gradient(circle at 40% 78%, rgba(202,165,106,.12) 0 1.1px, transparent 2px),
    linear-gradient(45deg, rgba(255,255,255,.05) 0 1px, transparent 1px 26px);
  background-size: 150px 150px, 210px 210px, 240px 240px, 26px 26px;
  opacity:.35;
  transform: rotate(8deg);
  animation: cs-pattern 14s ease-in-out infinite;
  z-index:-2;
}
@keyframes cs-pattern{
  0%,100%{ transform: translate3d(-1%, -1%, 0) rotate(8deg); }
  50%{ transform: translate3d(1.1%, .9%, 0) rotate(8deg); }
}
.cs-section::after{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(900px 520px at 50% 35%, transparent 30%, rgba(0,0,0,.22) 72%);
  z-index:-1;
}

.cs-wrap{
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 18px;
  text-align:center;
}

/* Header */
.cs-divider{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  margin-bottom: 12px;
}
.cs-line{
  width: min(260px, 30vw);
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(202,165,106,.60), transparent);
  transform: scaleX(.2);
  opacity:.25;
}
.cs-spark{
  color: var(--gold) !important;
  font-size: 20px;
  filter: drop-shadow(0 12px 18px rgba(202,165,106,.22));
  animation: cs-spark 2.8s ease-in-out infinite;
}
@keyframes cs-spark{
  0%,100%{ transform: translateY(0) rotate(0deg); opacity:.9; }
  50%{ transform: translateY(-3px) rotate(7deg); opacity:1; }
}

.cs-title{
  margin:0 0 10px;
  font-family: "Playfair Display", ui-serif, Georgia, serif;
  font-weight: 800;
  font-size: clamp(30px, 3.2vw, 48px);
  line-height: 1.1;
  text-shadow: 0 18px 40px rgba(0,0,0,.30);
}
.cs-gold{
  color: var(--gold) !important;
  position:relative;
}
.cs-gold::after{
  content:"";
  position:absolute; inset:-6px -10px;
  background: linear-gradient(115deg, transparent 0 38%, rgba(255,255,255,.22) 50%, transparent 62% 100%);
  transform: translateX(-60%);
  opacity:0;
  animation: cs-shimmer 3.9s ease-in-out infinite;
  pointer-events:none;
}
@keyframes cs-shimmer{
  0%{ transform: translateX(-60%); opacity:0; }
  20%{ opacity:.55; }
  45%{ transform: translateX(60%); opacity:0; }
  100%{ opacity:0; }
}
.cs-sub{
  margin:0 auto 22px;
  max-width: 760px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  color: var(--cream70) !important;
  font-size: 14px;
  line-height: 1.8;
}

/* Groups */
.cs-groups{
  margin-top: 22px;
  display:grid;
  gap: 18px;
}
.cs-group{
  padding: 18px 16px 12px;
  border-radius: 16px;
  background: rgba(246,239,230,.06);
  border: 1px solid rgba(202,165,106,.20);
  backdrop-filter: blur(6px);
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
  position:relative;
  overflow:hidden;
}

/* subtle moving highlight */
.cs-group::after{
  content:"";
  position:absolute; inset:-40%;
  background: linear-gradient(115deg, transparent 0 42%, rgba(202,165,106,.14) 50%, transparent 60% 100%);
  transform: translateX(-55%);
  opacity:0;
  animation: cs-sheen 5.2s ease-in-out infinite;
  pointer-events:none;
}
@keyframes cs-sheen{
  0%{ transform: translateX(-55%); opacity:0; }
  18%{ opacity:.8; }
  42%{ transform: translateX(55%); opacity:0; }
  100%{ opacity:0; }
}

.cs-h3{
  margin: 0 0 10px;
  font-family: "Playfair Display", ui-serif, Georgia, serif;
  font-weight: 800;
  font-size: 18px;
  color: var(--gold) !important;
  letter-spacing: .2px;
}

/* Chips */
.cs-chips{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap: 10px;
  padding-bottom: 8px;
}

.cs-chip{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(246,239,230,.08);
  border: 1px solid rgba(202,165,106,.28);
  color: rgba(246,239,230,.92) !important;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  font-size: 13px;
  line-height: 1;
  position: relative;
  overflow:hidden;
  transform-style: preserve-3d;
  transition: transform .28s ease, border-color .28s ease, background .28s ease, box-shadow .28s ease;
}

/* tiny dot pulse */
.cs-chip::before{
  content:"";
  width: 6px; height: 6px;
  border-radius: 999px;
  background: rgba(226,196,143,.95);
  box-shadow: 0 0 0 0 rgba(226,196,143,.30);
  animation: cs-pulse 2.6s ease-in-out infinite;
}
@keyframes cs-pulse{
  0%,100%{ box-shadow: 0 0 0 0 rgba(226,196,143,.30); opacity:.9; }
  50%{ box-shadow: 0 0 0 10px rgba(226,196,143,0); opacity:1; }
}

/* hover pop */
.cs-chip:hover{
  transform: translateY(-4px) scale(1.03);
  background: rgba(246,239,230,.12);
  border-color: rgba(202,165,106,.55);
  box-shadow: 0 22px 50px rgba(0,0,0,.22);
}

/* ===== Scroll reveal ===== */
.cs-reveal{
  opacity: 0;
  transform: translateY(24px);
  filter: blur(6px);
  transition: opacity .85s cubic-bezier(.2,.9,.2,1),
              transform .85s cubic-bezier(.2,.9,.2,1),
              filter .85s cubic-bezier(.2,.9,.2,1);
  transition-delay: var(--delay, 0ms);
  will-change: opacity, transform, filter;
}
.cs-reveal.cs-in{
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
.cs-head.cs-in .cs-line{
  transform: scaleX(1);
  opacity: 1;
  transition: transform 1.1s ease .12s, opacity .7s ease .12s;
}

/* chip pop-in once section is visible */
.cs-pop{
  opacity: 0;
  transform: translateY(10px) scale(.92);
  transition: opacity .55s cubic-bezier(.2,1.2,.2,1),
              transform .55s cubic-bezier(.2,1.2,.2,1);
  transition-delay: var(--chipDelay, 520ms);
}
.cs-pop.cs-chip-in{
  opacity: 1;
  transform: translateY(0) scale(1);
}

/* Responsive */
@media (max-width: 720px){
  .cs-group{ padding: 16px 12px 10px; }
  .cs-chip{ padding: 9px 12px; font-size: 12.5px; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .cs-section::before,
  .cs-spark,
  .cs-gold::after,
  .cs-group::after,
  .cs-chip::before{
    animation:none !important;
  }
  .cs-reveal, .cs-pop{
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
    transition:none !important;
  }
}/* End custom CSS */
/* Start custom CSS for html, class: .elementor-element-a3e2b0b *//* CTA SECTION (paste into Elementor Custom CSS / Site CSS) */
.cta-section{
  --paper:#fbf7f1;
  --cream:#f6efe6;
  --ink:#143b33;
  --maroon:#7b2d37;
  --gold:#caa56a;
  --gold2:#e2c48f;

  position: relative;
  padding: clamp(54px, 6vw, 92px) 0;
  background:
    radial-gradient(1000px 420px at 50% -15%, rgba(20,59,51,.08), transparent 55%),
    radial-gradient(900px 520px at 12% 35%, rgba(202,165,106,.15), transparent 62%),
    radial-gradient(900px 520px at 90% 35%, rgba(123,45,55,.12), transparent 62%),
    linear-gradient(180deg, var(--paper), var(--cream));
  overflow: hidden;
  isolation: isolate;
  text-align: center;
  color: var(--ink) !important;
}

/* Astra-safe color override */
.cta-section, .cta-section *{ color: inherit; }
.cta-section a, .cta-section a:visited, .cta-section a:hover{ color: inherit !important; text-decoration:none !important; }

.cta-section::before{
  content:"";
  position:absolute; inset:-35%;
  background:
    radial-gradient(circle at 230%, rgba(202,165,106,.18) 0 1.3px, transparent 2px),
    radial-gradient(circle at 75% 22%, rgba(123,45,55,.10) 0 1.2px, transparent 2px),
    radial-gradient(circle at 45% 80%, rgba(202,165,106,.12) 0 1.1px, transparent 2px),
    linear-gradient(45deg, rgba(20,59,51,.05) 0 1px, transparent 1px 26px);
  background-size: 160px 160px, 210px 210px, 240px 240px, 26px 26px;
  opacity:.33;
  transform: rotate(7deg);
  animation: cta-pattern 14s ease-in-out infinite;
  z-index:-2;
}
@keyframes cta-pattern{
  0%,100%{ transform: translate3d(-1%, -1%, 0) rotate(7deg); }
  50%{ transform: translate3d(1.1%, .9%, 0) rotate(7deg); }
}

/* subtle spotlight */
.cta-section::after{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(700px 260px at 50% 40%, rgba(255,255,255,.55), transparent 65%);
  opacity:.55;
  z-index:-1;
}

.cta-wrap{
  max-width: 980px;
  margin: 0 auto;
  padding: 0 18px;
}

/* Divider */
.cta-divider{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  margin-bottom: 12px;
}
.cta-line{
  width: min(260px, 30vw);
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(202,165,106,.65), transparent);
  transform: scaleX(.15);
  opacity:.25;
}
.cta-spark{
  color: var(--gold) !important;
  font-size: 20px;
  filter: drop-shadow(0 12px 18px rgba(202,165,106,.20));
  animation: cta-spark 2.8s ease-in-out infinite;
}
@keyframes cta-spark{
  0%,100%{ transform: translateY(0) rotate(0deg); opacity:.9; }
  50%{ transform: translateY(-3px) rotate(7deg); opacity:1; }
}

/* Title */
.cta-title{
  margin: 0 0 10px;
  font-family: "Playfair Display", ui-serif, Georgia, serif;
  font-weight: 900;
  font-size: clamp(26px, 3vw, 42px);
  line-height: 1.12;
  letter-spacing: .2px;
}
.cta-accent{
  color: var(--maroon) !important;
  position: relative;
}
.cta-accent::after{
  content:"";
  position:absolute; left:-8px; right:-8px; bottom:-6px;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(123,45,55,.55), transparent);
  transform: scaleX(.2);
  opacity:.0;
}

/* Sub */
.cta-sub{
  margin: 0 auto 18px;
  max-width: 620px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  font-size: 14px;
  line-height: 1.8;
  color: rgba(20,59,51,.72) !important;
}

/* Buttons */
.cta-actions{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap: 14px;
  margin-top: 8px;
}

.cta-btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap: 10px;
  min-width: 170px;
  padding: 12px 18px;
  border-radius: 10px;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial;
  font-weight: 800;
  font-size: 13px;
  letter-spacing: .2px;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 16px 44px rgba(0,0,0,.10);
  transform-style: preserve-3d;
  transition: transform .32s ease, box-shadow .32s ease, filter .32s ease;
  overflow:hidden;
  isolation:isolate;
}

/* glow layer */
.cta-btn__glow{
  content:"";
  position:absolute; inset:-40%;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.55), transparent 55%);
  transform: translateX(-55%);
  opacity:0;
  z-index:-1;
}
.cta-btn__arrow{
  opacity:.9;
  transform: translateX(-2px);
  transition: transform .25s ease, opacity .25s ease;
}

/* Gold button */
.cta-btn--gold{
  background: linear-gradient(180deg, rgba(226,196,143,.95), rgba(202,165,106,.92));
  color: #2b1a10 !important;
  border-color: rgba(202,165,106,.55);
}

/* Maroon button */
.cta-btn--maroon{
  background: linear-gradient(180deg, rgba(123,45,55,.98), rgba(84,22,30,.98));
  color: rgba(246,239,230,.95) !important;
  border-color: rgba(123,45,55,.55);
}

/* hover magic */
.cta-btn:hover{
  transform: translateY(-6px) scale(1.02);
  box-shadow: 0 26px 70px rgba(0,0,0,.16);
}
.cta-btn:hover .cta-btn__arrow{
  transform: translateX(2px);
  opacity: 1;
}
.cta-btn:hover .cta-btn__glow{
  animation: cta-glow 1.2s ease forwards;
}
@keyframes cta-glow{
  0%{ transform: translateX(-55%); opacity:0; }
  30%{ opacity:.85; }
  100%{ transform: translateX(55%); opacity:0; }
}

/* idle gentle float (premium) */
.cta-btn--gold{ animation: cta-float 4.8s ease-in-out infinite; }
.cta-btn--maroon{ animation: cta-float 5.2s ease-in-out infinite; animation-delay: .25s; }
@keyframes cta-float{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-3px); }
}

/* ===== Scroll Reveal ===== */
.cta-reveal{
  opacity: 0;
  transform: translateY(24px);
  filter: blur(7px);
  transition: opacity .9s cubic-bezier(.2,.9,.2,1),
              transform .9s cubic-bezier(.2,.9,.2,1),
              filter .9s cubic-bezier(.2,.9,.2,1);
  transition-delay: var(--delay, 0ms);
  will-change: opacity, transform, filter;
}
.cta-reveal.cta-in{
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

/* bring divider lines + underline in */
.cta-divider.cta-in .cta-line{
  transform: scaleX(1);
  opacity: 1;
  transition: transform 1.1s ease .12s, opacity .7s ease .12s;
}
.cta-title.cta-in .cta-accent::after{
  transform: scaleX(1);
  opacity: 1;
  transition: transform 1.1s ease .35s, opacity .7s ease .35s;
}

/* Mobile */
@media (max-width: 520px){
  .cta-btn{ width: 100%; max-width: 320px; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .cta-section::before,
  .cta-spark,
  .cta-btn--gold,
  .cta-btn--maroon{
    animation:none !important;
  }
  .cta-reveal{
    opacity:1 !important;
    transform:none !important;
    filter:none !important;
    transition:none !important;
  }
}
/* Force "View Our Menu" text to white */
.cta-btn--maroon,
.cta-btn--maroon:visited,
.cta-btn--maroon:hover,
.cta-btn--maroon:focus{
  color: #fff !important;
}

/* also keep the arrow white */
.cta-btn--maroon .cta-btn__arrow{
  color: #fff !important;
}
.cta-section a, .cta-section a:visited, .cta-section a:hover{
  color: inherit !important;
}

/* Astra-safe color override (EXCEPT CTA buttons) */
.cta-section a:not(.cta-btn),
.cta-section a:not(.cta-btn):visited,
.cta-section a:not(.cta-btn):hover{
  color: inherit !important;
  text-decoration: none !important;
}

/* Force maroon button text to white (normal/hover/visited) */
.cta-section a.cta-btn.cta-btn--maroon,
.cta-section a.cta-btn.cta-btn--maroon:visited,
.cta-section a.cta-btn.cta-btn--maroon:hover,
.cta-section a.cta-btn.cta-btn--maroon:focus{
  color: #fff !important;
}

/* keep arrow white too */
.cta-section a.cta-btn.cta-btn--maroon .cta-btn__arrow{
  color: #fff !important;
}/* End custom CSS */