/* =========================================================
   BUSINESS PROFILE PAGE
========================================================= */

.business-profile-page{
  max-width:1200px;
  margin:0 auto;
  padding:24px 18px 90px;
}
.address-value{
  white-space:normal !important;
  overflow:visible !important;
  text-overflow:unset !important;

  word-break:break-word;
  overflow-wrap:anywhere;

  line-height:1.6;
}
.inline-contact.address-row{
  align-items:flex-start;
}
/* =========================================================
   MODERN BREADCRUMB
========================================================= */

/* ==================================
   MODERN BREADCRUMB
================================== */

.breadcrumb-small{
  display:flex;
  align-items:center;
  flex-wrap:wrap;

  gap:8px;

  margin:20px 0 24px;
}

.breadcrumb-small .crumb-home{
  display:inline-flex;
  align-items:center;
  gap:6px;

  padding:6px 12px;

  border-radius:8px;

  background:linear-gradient(
    90deg,
    #4d6bff,
    #00c6c7
  );

  color:#fff;
  font-weight:600;

  text-decoration:none;

  transition:.2s ease;

  box-shadow:
    0 4px 14px rgba(65,91,224,.15);
}

.breadcrumb-small .crumb-home:hover{
  transform:translateY(-2px);

  box-shadow:
    0 8px 24px rgba(65,91,224,.22);
}

.breadcrumb-small .crumb-sep{
  color:#94a3b8;
  font-weight:500;
}

.breadcrumb-small .crumb-cat,
.breadcrumb-small .crumb-city{
  color:#4d6bff;
  font-weight:600;
  text-decoration:none;
}
.breadcrumb-small .crumb-biz{
  font-weight: 700;
}
.breadcrumb-small .crumb-cat:hover,
.breadcrumb-small .crumb-city:hover{
  text-decoration:underline;
}

/* =========================================================
   HERO SECTION
========================================================= */

.business-hero{
  display:grid;
  grid-template-columns:2fr 1fr;
  gap:24px;

  background:#fff;
  border-radius:24px;
  padding:28px;

  border:1px solid rgba(11,18,32,0.05);

  box-shadow:0 10px 30px rgba(11,18,32,0.05);
}

.business-hero-left{
  display:flex;

  gap:24px;

  min-width:0;
}

.business-main-info{
  display:flex;

  flex-direction:column;

  justify-content:flex-start;

  min-width:0;

  margin-left:2px;
}
.business-top-row{
  display:flex;

  align-items:flex-start;

  gap:14px;
  height: 75px;
}
/* =========================================================
   BUSINESS LOGO
========================================================= */

.business-logo-wrap{
  width:130px;
  height:130px;

  flex-shrink:0;
}

.business-logo{
  width:130px;
  

  object-fit:contain;

  border-radius:20px;

  background:#fff;

  border:1px solid rgba(11,18,32,0.06);
}



/* =========================================================
   MAIN INFO
========================================================= */

.business-main-info{
  min-width:0;
}

.business-main-info h1{
  margin:15px 0 14px;

  font-size:38px;
  line-height:1.2;

  color:var(--text);
}

.business-tagline{
  margin:0 0 20px;

  font-size:16px;
  line-height:1.8;

  color:var(--muted);
}



/* =========================================================
   BADGES
========================================================= */

.verified-row{
  display:flex;

  align-items:center;

  gap:10px;

  flex-wrap:wrap;
}

.verified-badge,
.elite-badge{
  padding:9px 16px;

  border-radius:999px;

  font-size:13px;
  font-weight:700;
}

.verified-badge{
  background:#dcfce7;
  color:#166534;
}

.elite-badge{
  background:#dbeafe;
  color:#1d4ed8;
}



/* =========================================================
   TRUST HIGHLIGHTS
========================================================= */

.trust-highlights{
  display:flex;
  flex-wrap:wrap;
  gap:12px;

  margin-bottom:24px;
}

.trust-highlights span{
  background:#f8fafc;

  border:1px solid rgba(11,18,32,0.05);

  padding:10px 14px;

  border-radius:999px;

  font-size:13px;
  font-weight:600;
}

/* =========================================================
   INLINE META
========================================================= */


.business-inline-meta span{
  font-size:14px;
  line-height:1.7;

  color:var(--muted);
}
.business-hero-right{
  display:flex;
  align-items:flex-start;
}
/* =========================================================
   CONTACT PANEL
========================================================= */

.business-contact-card{
  width:100%;

  background:#fff;

  border-radius:22px;

  padding:24px;

  border:1px solid rgba(11,18,32,0.05);

  box-shadow:0 10px 30px rgba(11,18,32,0.04);
}



/* =========================================================
   INFO BLOCK
========================================================= */

.contact-info-block{
  padding-bottom:12px;
  margin-bottom:12px;

  border-bottom:1px solid rgba(11,18,32,0.06);
}
/* =========================================================
   INLINE CONTACT
========================================================= */

.inline-contact{
  display:grid;

  grid-template-columns:140px 1fr;

  align-items:center;

  gap:16px;
}



/* =========================================================
   LABEL
========================================================= */

.contact-label{
  display:flex;
  align-items:center;

  gap:6px;

  font-size:13px;
  font-weight:700;

  letter-spacing:0.4px;

  text-transform:uppercase;

  color:var(--muted);
   line-height:1;
}

.contact-label .hours-icon{
  font-size:18px;
  line-height:1;
}
.hours-icon{
  font-size:18px;

  position:relative;

  top:-1px;
}
/* =========================================================
   VALUE
========================================================= */

.contact-value{
  display:block;

  font-size:16px;
  font-weight:600;

  line-height:1.6;

  color:var(--text);
  overflow:hidden;

text-overflow:ellipsis;

white-space:nowrap;
}



.direction-link{
  display:flex;
  align-items:center;
  justify-content:center;

  gap:8px;

  min-height:50px;

  
  padding:12px 16px;

  border-radius:16px;

  background:linear-gradient(90deg, #4d6bff 0%, #00c6c7 100%);
  

  border:1px solid rgba(11,18,32,0.06);

  color:#fff;

  font-size:14px;
  font-weight:700;

  transition:0.2s ease;
  width:auto;
  
}
.business-contact-card .direction-link{
  width:60%;
  margin:0 auto;
  margin-bottom: 5px
}
.direction-link:hover{
  

  transform:translateY(-1px);
}

/* =========================================================
   INLINE META WRAP
========================================================= */

.business-inline-meta{
  display:flex;
  flex-wrap:wrap;
  gap:14px;

  margin-top:18px;
}



/* =========================================================
   PREMIUM MINI META
========================================================= */

.premium-mini-meta{
  display:flex;
  flex-direction:column;

 min-width:0;

  padding:14px 16px;

  border-radius:16px;

  background:#eef2ff;

  border:1px solid rgba(11,18,32,0.05);
  align-items:center;

text-align:center;
}



/* =========================================================
   PREMIUM LABEL
========================================================= */

.premium-meta-label{
  margin-bottom:6px;

  font-size:12px;
  font-weight:700;

  letter-spacing:0.4px;

  text-transform:uppercase;

  color:#4d6bff !important;
}



/* =========================================================
   PREMIUM VALUE
========================================================= */

.premium-meta-value{
  font-size:14px;
  font-weight:600;

  line-height:1.6;

  color:var(--text);
}



/* =========================================================
   SIMPLE META
========================================================= */

/* =========================================================
   CTA GROUP
========================================================= */

.business-cta-group{
  display:flex;
  flex-direction:column;
  gap:12px;
}



.primary-business-cta{
  display:flex;
  align-items:center;
  justify-content:center;

  min-height:52px;

  padding:14px 18px;

  border-radius:16px;

  background:linear-gradient(
    90deg,
    #16a34a,
    #22c55e
  );

  color:#fff;

  font-size:15px;
  font-weight:700;

 transition:0.2s ease;
}

.primary-business-cta:hover{
  transform:translateY(-1px);

  box-shadow:
    0 14px 28px rgba(34,197,94,0.22);
}



/* =========================================================
   WEBSITE TRUNCATION
========================================================= */

.website-value{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}



/* =========================================================
   HOURS
========================================================= */

.hours-list{
  display:flex;
  flex-direction:column;
  gap:12px;
}

.hours-row{
  display:grid;

  grid-template-columns:122px 1fr;

  gap:16px;

  font-size:14px;
  line-height:1.7;
  margin-left: 22px;
  margin-top: 10px;
}

.hours-row strong{
  font-weight:600;
}



/* =========================================================
   CTA BUTTON
========================================================= */

.profile-cta{
  display:flex;
  align-items:center;
  justify-content:center;

  text-align:center;

  min-height:52px;

  padding:14px 16px;

  border-radius:14px;

  font-weight:700;

  transition:0.2s ease;
}


/* =========================================================
   COMMON PROFILE SECTION
========================================================= */

.profile-section{
  margin-top:28px;

  background:#fff;

  border-radius:24px;

  padding:28px;

  border:1px solid rgba(11,18,32,0.05);

  box-shadow:0 10px 30px rgba(11,18,32,0.04);
}

.section-heading-wrap{
  margin-bottom:20px;
}

.section-heading-wrap h2{
  margin:0;

  font-size:28px;
  line-height:1.3;
}

/* =========================================================
   MODERN SERVICES GRID
========================================================= */

.services-modern-grid{
  display:grid;

  grid-template-columns:
    repeat(3, minmax(0, 1fr));

  gap:14px;
}



/* =========================================================
   SERVICE ITEM
========================================================= */

.service-modern-item{
  position:relative;

  display:flex;
  align-items:center;

  min-height:40px;

  padding:10px 16px 10px 18px;

  border-radius:12px;

  background:#fff;

  border:1px solid rgba(11,18,32,0.06);

  font-size:14px;
  font-weight:600;

  color:var(--text);

  box-shadow:
    0 4px 12px rgba(11,18,32,0.03);

  transition:0.2s ease;
}



/* LEFT ACCENT */

.service-modern-item::before{
  content:"";

  position:absolute;

  left:0;
  top:0;

  width:4px;
  height:100%;

  border-radius:
    12px 0 0 12px;

  background:linear-gradient(
    180deg,
    var(--primary-500),
    var(--accent-aqua)
  );
}



/* HOVER */

.service-modern-item:hover{
  transform:translateY(-1px);

  box-shadow:
    0 8px 18px rgba(11,18,32,0.06);
}

/* =========================================================
   BUSINESS MEDIA
========================================================= */

.business-media-grid{
  display:grid;

  grid-template-columns:
    1.1fr 0.9fr;

  gap:18px;

  align-items:center;
}


/* =========================================================
   YOUTUBE PREVIEW
========================================================= */

.youtube-video-preview{
  position:relative;

  border-radius:22px;

  background:#000;

  aspect-ratio:16/9;

  min-height:320px;
}

/* =========================================================
   ICON
========================================================= */
.youtube-fallback{
  position:absolute;

  inset:0;

  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;

  gap:18px;

  background:#111827;

  color:#fff;

  cursor:pointer;
}
.youtube-fallback-icon{
  display:flex;
  align-items:center;
  justify-content:center;

  width:120px;
  height:84px;

  border-radius:20px;

  background:#ff0000;

  color:#fff;

  box-shadow:
    0 16px 30px rgba(0,0,0,0.24);
}



.youtube-fallback-icon svg{
  width:48px;
  height:48px;
}



/* =========================================================
   LOADED IFRAME
========================================================= */

.youtube-player-active{
  position:absolute;

  inset:0;

  width:100%;
  height:100%;

  border:0;

  display:block;

  border-radius:22px;

  background:#000;
  pointer-events:auto;

touch-action:auto;
}


/* =========================================================
   RIGHT GALLERY
========================================================= */

.media-gallery-layout{
  display:flex;
  flex-direction:column;

  gap:14px;
}



/* =========================================================
   IMAGES
========================================================= */

.media-gallery-layout img{
  width:100%;
  height:100%;

  object-fit:cover;

  border-radius:18px;
}



/* =========================================================
   LARGE IMAGE
========================================================= */

.gallery-large-image{
  height:300px;

  overflow:hidden;

  border-radius:18px;
}



/* =========================================================
   SMALL GRID
========================================================= */

.gallery-small-grid{
  display:grid;

  grid-template-columns:
    repeat(2, minmax(0,1fr));

  gap:14px;
}



/* =========================================================
   SMALL IMAGES
========================================================= */

.gallery-small-grid img{
  height:155px;
}

/* =========================================================
   TABLET
========================================================= */

@media (max-width: 1024px){

  .services-modern-grid{
    grid-template-columns:
      repeat(3, minmax(0, 1fr));
  }

}



/* =========================================================
   MOBILE
========================================================= */

@media (max-width: 640px){

  .services-modern-grid{
    grid-template-columns:
      repeat(2, minmax(0, 1fr));

    gap:12px;
  }

}
/* =========================================================
   MODERN PRICING GRID
========================================================= */

.pricing-modern-grid{
  display:grid;

  grid-template-columns:
    repeat(2, minmax(0, 1fr));

  gap:32px;
}



/* =========================================================
   COLUMN
========================================================= */

.pricing-column{
  display:flex;
  flex-direction:column;
}



/* =========================================================
   ROW
========================================================= */

.pricing-row{
  display:flex;
  align-items:center;
  justify-content:space-between;

  gap:20px;

  min-height:52px;

  border-bottom:
    1px solid rgba(11,18,32,0.06);

  transition:0.2s ease;
}



/* =========================================================
   HOVER
========================================================= */

.pricing-row:hover{
  padding-left:6px;
}



/* =========================================================
   SERVICE
========================================================= */

.pricing-service{
  font-size:14px;
  font-weight:600;

  line-height:1.5;

  color:var(--text);
}



/* =========================================================
   PRICE
========================================================= */

.pricing-price{
  flex-shrink:0;

  font-size:14px;
  font-weight:700;

  color:var(--primary-500);
}



/* =========================================================
   TABLET
========================================================= */

@media (max-width: 1024px){

  .pricing-modern-grid{
    grid-template-columns:
      repeat(2, minmax(0, 1fr));

    gap:24px;
  }

}



/* =========================================================
   MOBILE
========================================================= */

@media (max-width: 640px){

  .pricing-modern-grid{
    grid-template-columns:1fr;
  }

}
/* =========================================================
   OFFERS
========================================================= */

.offers-grid{
  display:grid;

  grid-template-columns:
    repeat(4, minmax(0,1fr));

  gap:14px;
}

.offer-card{
  background:linear-gradient(
    135deg,
    #eef4ff,
    #f0fdfa
  );

  border-radius:18px;

  padding:18px;
}

.offer-badge{
  display:inline-flex;

  margin-bottom:10px;

  background:#fff;

  padding:6px 12px;

  border-radius:999px;

 font-size:11px;
  font-weight:700;
}

.offer-card h3{
  margin:0 0 8px;

 font-size:18px;
}

.offer-card p{
  margin:0;

  color:var(--muted);

  line-height:1.7;
  font-size:14px;
}

.claim-offer-btn{
  display:flex;
  align-items:center;
  justify-content:center;

  width:100%;

  min-height:42px;

  margin-top:14px;

  padding:10px 16px;

  border-radius:12px;

  background:linear-gradient(
    90deg,
    var(--primary-500),
    var(--accent-aqua)
  );

  color:#fff;

  font-size:13px;
  font-weight:700;

  text-decoration:none;

  transition:0.2s ease;
}



.claim-offer-btn:hover{
  transform:translateY(-1px);

  box-shadow:
    0 10px 24px rgba(77,107,255,0.20);
}

/* =========================================================
   DISCOUNT CODE
========================================================= */

.discount-code-wrap{
  display:flex;
  flex-direction:column;

  gap:6px;

  margin-top:14px;
}



/* =========================================================
   CODE LABEL
========================================================= */

.discount-code-label{
  font-size:11px;
  font-weight:700;

  letter-spacing:0.4px;

  text-transform:uppercase;

  color:var(--muted);
}



/* =========================================================
   CODE VALUE
========================================================= */

.discount-code-value{
  display:inline-flex;
  align-items:center;
  justify-content:center;

  width:fit-content;

  min-height:34px;

  padding:6px 12px;

  border-radius:10px;

  background:#fff;

  border:1px dashed rgba(11,18,32,0.15);

  font-size:13px;
  font-weight:700;

  letter-spacing:1px;

  color:var(--primary-500);
}

.premium-offer-card{
  position:relative;

  overflow:hidden;

  padding:28px;

  border-radius:24px;

  background:
    linear-gradient(
      135deg,
      #eef4ff 0%,
      #ffffff 45%,
      #f0fdfa 100%
    );

  border:1px solid rgba(77,107,255,0.10);

  box-shadow:
    0 12px 30px rgba(77,107,255,0.08);

  transition:all .25s ease;
}

.premium-offer-card:hover{
  transform:translateY(-4px);

  box-shadow:
    0 20px 40px rgba(77,107,255,0.15);
}

.offer-top-label{
  display:inline-flex;

  padding:6px 12px;

  border-radius:999px;

  background:#fff;

  color:#4d6bff;

  font-size:11px;

  font-weight:700;

  letter-spacing:.8px;

  text-transform:uppercase;
}

.offer-amount{
  margin-top:18px;

  font-size:52px;

  font-weight:800;

  line-height:1;

  background:
    linear-gradient(
      90deg,
      #4d6bff,
      #00c6c7
    );

  -webkit-background-clip:text;

  -webkit-text-fill-color:transparent;
}

.offer-subtitle{
  margin-top:6px;

  font-size:15px;

  font-weight:700;

  color:#0f172a;
}

.offer-description{
  margin-top:18px;

  line-height:1.8;

  color:#64748b;
}

.offer-footer{
  margin-top:20px;

  padding-top:16px;

  border-top:
    1px solid rgba(11,18,32,0.06);

  font-size:13px;

  font-weight:600;

  color:#16a34a;
}
/* =========================================================
   ACHIEVEMENTS MINI GRID
========================================================= */

.achievements-mini-grid{
  display:grid;

  grid-template-columns:
    repeat(2, minmax(0,1fr));

  gap:16px;
}



/* =========================================================
   MINI CARD
========================================================= */

.achievement-mini-card{
  display:flex;
  flex-direction:column;
  align-items:center;

  text-align:center;

  min-height:175px;

  padding:20px 16px 16px;

  border-radius:18px;

  background:#fff;

  border:1px solid rgba(11,18,32,0.06);

  box-shadow:
    0 4px 12px rgba(11,18,32,0.04);

  transition:0.2s ease;
}

.achievement-mini-card:hover{
  transform:translateY(-2px);
}



/* =========================================================
   ICON
========================================================= */

.achievement-mini-icon{
  margin-bottom:18px;

  font-size:30px;

  line-height:1;
}



/* =========================================================
   TITLE
========================================================= */

.achievement-title{
  flex:1;

  display:flex;
  align-items:center;
  justify-content:center;

  font-size:15px;
  font-weight:700;

  line-height:1.5;

  color:var(--text);
}



/* =========================================================
   BADGE
========================================================= */

.achievement-badge{
  display:flex;
  align-items:center;
  justify-content:center;

  min-width:100px;
  min-height:34px;

  margin-top:18px;

  padding:6px 14px;

  border-radius:10px;

  background:linear-gradient(
    90deg,
    var(--primary-500),
    var(--accent-aqua)
  );

  color:#fff;

  font-size:13px;
  font-weight:700;
}

/* =========================================================
   AMENITIES GRID
========================================================= */

.amenities-grid{
  display:grid;

  grid-template-columns:
    repeat(2, minmax(0,1fr));

  gap:14px;
}



/* =========================================================
   AMENITY ITEM
========================================================= */

.amenity-item{
  position:relative;

  padding:14px 14px 14px 34px;

  border-radius:16px;

  background:#fff;

  border:1px solid rgba(11,18,32,0.05);

  line-height:1.6;
}



/* BLUE STAR BULLET */

.amenity-item::before{
  content:"★";

  position:absolute;

  left:14px;
  top:50%;

  transform:translateY(-50%);

  font-size:16px;
  font-weight:700;

  line-height:1;

  color:var(--primary-500);
}



/* =========================================================
   SERVING AREAS
========================================================= */

.serving-areas-wrap{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.serving-areas-wrap span{
  padding:11px 16px;

  border-radius:999px;

  background:#f8fafc;

  border:1px solid rgba(11,18,32,0.05);

  font-size:14px;
}



/* =========================================================
   FAQ
========================================================= */

.faq-list details{
  border:1px solid rgba(11,18,32,0.06);

  border-radius:18px;

  padding:20px;

  margin-bottom:14px;

  background:#fff;
}

.faq-list summary{
  cursor:pointer;

  font-weight:700;

  font-size:16px;
}

.faq-list p{
  margin-top:14px;

  line-height:1.8;

  color:var(--muted);
}

/* =========================================================
   TWO COLUMN HIGHLIGHT SECTIONS
========================================================= */

.two-column-highlights-wrap{
  display:grid;

  grid-template-columns:
    repeat(2, minmax(0,1fr));

  gap:22px;

  align-items:start;
}

/* =========================================================
   GALLERY IMAGE INTERACTION
========================================================= */

.media-gallery-layout img{
  cursor:zoom-in;

  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease;
}



.media-gallery-layout img:hover{
  transform:scale(1.02);

  box-shadow:
    0 12px 30px rgba(0,0,0,0.14);
}

/* =========================================================
   IMAGE LIGHTBOX
========================================================= */

.image-lightbox{
  position:fixed;

  inset:0;

  z-index:9999;

  display:flex;
  align-items:center;
  justify-content:center;

  padding:40px;

  background:rgba(0,0,0,0.88);

  backdrop-filter:blur(10px);

  opacity:0;
  visibility:hidden;

  transition:0.25s ease;
}



/* ACTIVE */

.image-lightbox.active{
  opacity:1;
  visibility:visible;
}


/* =========================================================
   LIGHTBOX IMAGE
========================================================= */

.lightbox-image{
  max-width:92vw;
  max-height:90vh;
  transition:transform 0.2s ease;
  border-radius:20px;

  object-fit:contain;

  box-shadow:
    0 25px 60px rgba(0,0,0,0.35);



  animation:lightboxZoom 0.22s ease;
  transform-origin:center center;

position:relative;

z-index:5;
}


/* =========================================================
   CLOSE BUTTON
========================================================= */

.lightbox-close{
  position:absolute;

  top:22px;
  right:28px;

  width:54px;
  height:54px;

  display:flex;
  align-items:center;
  justify-content:center;

  border-radius:999px;

  background:rgba(255,255,255,0.12);

  color:#fff;

  font-size:34px;
  line-height:1;

  cursor:pointer;

  transition:0.2s ease;
}



.lightbox-close:hover{
  background:rgba(255,255,255,0.20);

  transform:scale(1.06);
}
/* =========================================================
   LIGHTBOX NAVIGATION
========================================================= */

.lightbox-nav{
  position:absolute;

  top:50%;

  transform:translateY(-50%);

  width:60px;
  height:60px;

  border:none;

  border-radius:999px;

  background:rgba(255,255,255,0.14);

  color:#fff;

  font-size:34px;

  cursor:pointer;

  transition:0.2s ease;

  z-index:10;
}



.lightbox-nav:hover{
  background:rgba(255,255,255,0.22);

  transform:
    translateY(-50%)
    scale(1.06);
}



/* LEFT */

.lightbox-prev{
  left:24px;
}



/* RIGHT */

.lightbox-next{
  right:24px;
}
/* =========================================================
   LIGHTBOX ANIMATION
========================================================= */

@keyframes lightboxZoom{

  from{
    transform:scale(0.92);
    opacity:0;
  }

  to{
    transform:scale(1);
    opacity:1;
  }

}
/* =========================================================
   MOBILE STICKY CTA
========================================================= */
.mobile-sticky-cta{
  position:fixed;

  left:0;
  right:0;
  bottom:0;

  z-index:1500;

  display:none;

  gap:6px;

  padding:6px;

  background:#fff;

  border-top:1px solid rgba(11,18,32,.06);

  box-shadow:
    0 -6px 20px rgba(0,0,0,.08);
}
.mobile-sticky-cta a{
  flex:1;

  display:flex;
  align-items:center;
  justify-content:center;

  min-height:34px;

  padding:6px 8px;

  border-radius:10px;

  font-size:10px;
  font-weight:700;

  line-height:1;

  background:linear-gradient(
    90deg,
    var(--primary-500),
    var(--accent-aqua)
  );

  color:#fff;

  white-space:nowrap;
}
.mobile-sticky-cta .direction-link{
  flex:1;

  width:auto;

  margin:0;

  min-height:34px;

  padding:6px 8px;

  border-radius:10px;

  font-size:10px;

  white-space:nowrap;
}
/* =========================================================
   RESPONSIVE - TABLET
========================================================= */

@media(max-width:980px){

  .business-hero,
  .gallery-grid{
    grid-template-columns:1fr;
  }

.business-hero-left{
  flex-direction:row;

  align-items:flex-start;

  gap:16px;
}
.offers-grid{
  grid-template-columns:
    repeat(3, minmax(0,1fr));
}
  
.business-media-grid{
  grid-template-columns:1fr;
}
}



/* =========================================================
   RESPONSIVE - MOBILE
========================================================= */

@media(max-width:720px){

  .business-profile-page{
  padding:16px 12px 70px;
}
.business-hero-left{
  flex-direction:column;

  gap:14px;
}



.business-top-row{
  display:flex;

  align-items:flex-start;

  gap:10px;
}
.business-main-info{
  width:100%;
}
.business-hero{
  overflow:hidden;
}



.business-logo-wrap{
  width:120px;
  height:70px;

  flex-shrink:0;

  margin-bottom:0;
}



.business-logo{
  width:100%;
  height:100%;

  object-fit:contain;

  padding:6px;
}



.verified-row{
  display:flex;

  flex-direction:column;

  align-items:flex-start;

  gap:8px;
}



.verified-badge,
.elite-badge{
  padding:8px 12px;

  font-size:11px;
}

.business-tagline{
  width:100%;

  max-width:100%;

  overflow-wrap:anywhere;

  word-break:break-word;

  line-height:1.9;
}
.trust-highlights{
  gap:8px;
}

.trust-highlights span{
  padding:8px 12px;

  font-size:12px;
  max-width:100%;

overflow-wrap:anywhere;
}

.achievements-mini-grid{
  grid-template-columns:
    repeat(2, minmax(0,1fr));

  gap:12px;
}
    .two-column-highlights-wrap{
  grid-template-columns:1fr;
}
.offer-amount{
    font-size:42px;
  }
.amenity-item{
  display:flex;

  align-items:center;

  gap:8px;

  padding:12px 14px;
}



.amenity-item::before{
  position:static;

  transform:none;

  flex-shrink:0;

  font-size:14px;
}
.amenities-grid{
  grid-template-columns:1fr;
  gap: 10px;
}
.section-heading-wrap h2{
  font-size: 24px;
}
.offer-card h3{
  font-size: 14px;
}
.claim-offer-btn{
  align-items: center;
  text-align: center;
  
  padding: 0px;
}
.inline-contact{
  grid-template-columns:85px 1fr;

  gap:10px;
}
.hours-row{
  

  gap:2px;

  margin-left:0;
}

.business-contact-card{
  overflow:hidden;
}
.gallery-large-image{
  height:220px;
}
.lightbox-nav{
  width:48px;
  height:48px;

  font-size:28px;
}


.gallery-small-grid img{
  height:140px;
}
.achievement-mini-card{
  min-height:170px;

  padding:16px 12px 14px;
}
  .business-main-info h1{
    font-size:30px;
  }

.offers-grid{
  grid-template-columns:
    repeat(2, minmax(0,1fr));

  gap:12px;
}
.business-inline-meta{
  display:grid;

  grid-template-columns:1fr;

  gap:12px;

  width:100%;
}
.business-hero{
  padding:18px;
}
  .mobile-sticky-cta{
    display:flex;
  }

  .business-media-grid{
  grid-template-columns:1fr;

  gap:16px;
}



.media-video-wrap{
  width:100%;
}



.youtube-video-preview{
  overflow:hidden;

touch-action:auto;
  width:100%;

  min-height:auto;

  max-width:100%;
}



.media-gallery-layout{
  width:100%;
}



.media-gallery-layout img{
  width:100%;
}
}

/* =========================================================
   MOBILE LIGHTBOX
========================================================= */

@media(max-width:720px){

  .image-lightbox{
    padding:16px;
  }

  .lightbox-image{
    max-width:100%;
    max-height:82vh;

    border-radius:16px;
  }

  .lightbox-close{
    top:14px;
    right:14px;

    width:46px;
    height:46px;

    font-size:28px;
  }


  .lightbox-prev{
  left:10px;
}

.lightbox-next{
  right:10px;
}
}

html,
body{
  max-width:100%;
}

.direction-link{
  cursor:pointer;
}
@media (max-width: 720px){

  .offers-grid{
    grid-template-columns:1fr !important;
  }

}


.premium-offer-card{
  text-align:center;

  display:flex;
  flex-direction:column;
  align-items:center;
}

.offer-description{
  text-align:center;
  max-width:260px;
}

.offer-footer{
  width:100%;
  text-align:center;
}