.elementor-61058 .elementor-element.elementor-element-21c64c1{--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;}.elementor-61058 .elementor-element.elementor-element-fee3197{--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;}@media(min-width:768px){.elementor-61058 .elementor-element.elementor-element-fee3197{--content-width:1200px;}}/* Start custom CSS for html, class: .elementor-element-698a8fe *//* =========================
   ROOT + GLOBAL
========================= */
:root{
  --brand:#86198f;
  --brand2:#8b5cf6;
  --brand-soft:#fdf4ff;
  --ink:#111827;
  --muted:#6b7280;
  --line:#e5e7eb;
  --radius:22px;
  --shadow:0 18px 50px rgba(15,23,42,.12);

  /* consistent container padding */
  --wrap-pad: clamp(14px, 4vw, 20px);

  /* responsive handle sizes etc (if needed later) */
}

*{ box-sizing:border-box; font-family:'Poppins',sans-serif; }

html, body{ overflow-x:hidden; }

.wrap1{
  max-width:1180px;
  margin:0 auto;
  padding-inline: var(--wrap-pad);
}

/* =========================
   HERO
========================= */
.loc-hero{
  position:relative;
  overflow:hidden;
  background:linear-gradient(180deg,#fff,#faf5ff);
}

.loc-hero-inner {
    display: grid;
    grid-template-columns: 1.25fr 1fr;
    align-items: center;
    gap: 34px;
    padding: 60px 20px;
}


section.loc-grid-wrap {
    padding-top: 100px;
    padding-left: 0px;
    padding-right: 0px;
}

.tag{
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.14em;
  background:#fdf4ff;
  border-radius:999px;
  border:1px solid #f3e8ff;
  padding:6px 10px;
  margin-bottom:10px;
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.loc-hero-title1{
  font-size:clamp(28px,4.2vw,48px);
  margin:0 0 8px;
  font-weight:700;
  color:#000;
  line-height:1.12;
}

.loc-hero-sub{
  color:var(--muted);
  max-width:60ch;
  margin:0;
  line-height:1.6;
}

/* =========================
   BLOBS
========================= */
.blob{
  position:absolute;
  filter:blur(18px);
  opacity:.55;
  background:
    radial-gradient(circle,#f0abfc,transparent 60%),
    radial-gradient(circle,#c4b5fd,transparent 60%);
  border-radius:50%;
  pointer-events:none;
}

.blob-1{
  width:380px;
  height:380px;
  left:-120px;
  top:-80px;
  animation:float 12s infinite;
}

.blob-2{
  width:320px;
  height:320px;
  right:-120px;
  bottom:-80px;
  animation:float 14s infinite reverse;
}

@keyframes float{
  0%{ transform:translate(0,0); }
  50%{ transform:translate(10px,-12px); }
  100%{ transform:translate(0,0); }
}

/* =========================
   GLASS CARD
========================= */
.glass-card{
  border-radius:24px;
  background:rgba(255,255,255,.4);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.6);
  box-shadow:var(--shadow);
  max-width: 100%;
}

.glass-inner{
  padding:28px;
  position:relative;
}

.sparkle{
  position:absolute;
  inset:-40% -10% auto auto;
  width:200px;
  height:200px;
  background:radial-gradient(rgba(139,92,246,.5),transparent);
  filter:blur(12px);
  animation:drift 12s infinite alternate;
  pointer-events:none;
}

@keyframes drift{
  from{ transform:translate(-10px,-10px); }
  to{ transform:translate(10px,6px); }
}

/* =========================
   BUTTONS
========================= */
.btn-call,
.btn-map,
.btn-ghost{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px 18px;
  border-radius:999px;
  text-decoration:none;
  font-weight:700;
  transition:.18s;
  white-space:nowrap;
}

.btn-call{
  background:linear-gradient(135deg,#ec4899,#8b5cf6);
  color:#fff;
}

.btn-call:hover{
  transform:translateY(-1px);
  box-shadow:0 20px 40px rgba(236,72,153,.25);
}

.btn-map{
  background:#fdf4ff;
  color:#7c3aed;
  border:1px solid #f3e8ff;
  font-size:14px;
}

.btn-ghost{
  border:1px solid #e5e7eb;
  color:#111827;
  background:#fff;
  font-size:14px;
}

.btn-ghost:hover{ background:#f9fafb; }

/* =========================
   GRID / CARDS
========================= */
.loc-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:22px;
}

.loc-card{
  background:#fff;
  border-radius:var(--radius);
  border:1px solid #eee;
  padding: clamp(14px, 4vw, 18px); /* responsive padding */
  box-shadow:var(--shadow);
  opacity:0;
  transform:translateY(10px);
  transition:.6s;
  max-width:100%;
}

.loc-card.is-visible{
  opacity:1;
  transform:translateY(0);
}

.loc-card-head{
  display:flex;
  align-items:center;
  gap:10px;
  justify-content:space-between;
  margin-bottom:8px;
}

.loc-card h2{
  font-size:clamp(18px,1.8vw,22px);
  margin:0;
}

.badge{
  background:#eef2ff;
  color:#3730a3;
  border-radius:999px;
  padding:6px 10px;
  font-weight:700;
  font-size:12px;
  flex:0 0 auto;
}

.addr{
  margin:6px 0 14px;
  color:#374151;
  line-height:1.5;
}

.loc-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:12px;
}

.loc-meta{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:10px;
}

.loc-meta div{
  background:#fafafa;
  border:1px solid #eee;
  padding:10px;
  border-radius:12px;
  display:flex;
  flex-direction:column;          /* keep consistent like your latest override */
  justify-content:space-between;
  gap:6px;
}

.loc-meta strong{ font-weight:700; }
.loc-meta span{ color:#374151; }

/* =========================
   ⭐ GOOGLE STARS
========================= */
.g-stars-mini{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 14px;
  margin-top:12px;
  border:1px solid #e5e7eb;
  border-radius:999px;
  background:#fff;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
  text-decoration:none;
  transition:.22s;
}

.g-stars-mini:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 25px rgba(0,0,0,.08);
}

.g-stars-mini svg{ width:16px; height:16px; }
.score{ color:#111; }
.count{ color:#6b7280; font-weight:600; }

/* =========================
   CTA STRIP
========================= */
.loc-cta-strip{
  background:rgba(236,72,153,.08);
  padding:20px 0;
  margin-top:40px;
}

.strip-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
  padding-inline: var(--wrap-pad); /* keep aligned with wrap */
}

.strip-text{
  color:#111;
  font-weight:600;
}

.wrap.strip-inner {
    padding: 1px 20px;
}
/* =========================
   RESPONSIVE
========================= */

/* Tablets (≤ 1024px) */
@media (max-width:1024px){
  .loc-hero-inner{
    grid-template-columns:1fr;
    gap:22px;
    padding:44px 0;
  }
  .loc-hero-art{ order:2; }
  .loc-hero-copy{ order:1; text-align:center; }

  .btn-call{
    width:100%;
    max-width:340px;
    margin:14px auto 0;
  }

  .glass-card{
    max-width:560px;
    margin:0 auto;
  }

  .loc-grid{ grid-template-columns:repeat(2,1fr); }
}

/* Large phones / small tablets (≤ 768px) */
@media (max-width:768px){
  .loc-hero-inner{ padding:36px 0; }

  .loc-grid{ grid-template-columns:1fr; }
  .loc-meta{ grid-template-columns:1fr; }

  .btn-map, .btn-ghost{
    flex:1 1 auto;
    min-width: 140px;
  }

  .badge{ font-size:11px; }

  /* prevent buttons from forcing overflow */
  .loc-actions{
    gap:10px;
  }
}

/* Phones (≤ 560px) */
@media (max-width:560px){
  .loc-hero-inner{ padding:28px 0; }

  .loc-hero-title1{
    font-size:clamp(24px,6vw,32px);
  }

  .loc-hero-sub{ font-size:14px; }

  .strip-inner{
    flex-direction:column;
    align-items:stretch;
    text-align:center;
  }

  .loc-cta-strip .btn-call{
    width:100%;
    max-width:none;
    margin:0;
  }
  .wrap1.loc-hero-inner {
    padding: 15px;
}
.loc-cta-strip {
    background: rgba(236,72,153,.08);
    padding: 20px 20px;
    margin-top: 40px;
}
section.loc-grid-wrap {
    padding-top: 20px;
    padding-left: 0px;
    padding-right: 0px;
}
}

/* =========================
   MOTION SAFETY
========================= */
@media (prefers-reduced-motion:reduce){
  .sparkle, .blob-1, .blob-2, .loc-card{ animation:none; }
  .loc-card{ transition:none; }
}/* End custom CSS */