:root {
  --brand: #662d91;
}
a{
  text-decoration: none !important;
  color: #000;
}
html,
body {
  scroll-behavior: smooth;
}

.navbar .nav-link.active {
  color: var(--brand) !important;
  font-weight: 600;
}
.navbar-expand-lg .navbar-nav .nav-link{
  color: #000 !important;
}

.hero {
  height: 70vh;
  min-height: 420px;
}

.hero-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: brightness(0.7);
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, .35), rgba(0, 0, 0, .55));
}

.hero-content {
  position: relative;
  z-index: 1;
  padding-top: 18vh;
}

.card img {
  object-fit: cover;
  height: 220px;
}

footer .btn {
  border-radius: 999px;
}

.rounded-4 {
  border-radius: 1rem !important;
}

.gallery-grid img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.btn-primary {
  background: var(--brand);
  border-color: var(--brand);
}

.btn-outline-primary {
  color: var(--brand);
  border-color: var(--brand);
}

.btn-outline-primary:hover {
  background: var(--brand);
  border-color: var(--brand);
}


/* ===== Enhanced Nav & Header ===== */
:root {
  --brand: #662d91;
  --ink: #111;
  --muted: #6b7280;
}

body {
  padding-top: 74px;
}

.luxe-nav {
  background: #fff;
  backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid rgba(0, 0, 0, .06);
}

.navbar-brand .brand-mark {
  display: inline-grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--brand), #b08cff);
  color: #fff;
  font-weight: 700;
}

.nav-link {
  position: relative;
  margin: 0 .25rem;
  padding: .5rem .75rem !important;
}

.nav-link::after {
  content: "";
  position: absolute;
  left: .75rem;
  right: .75rem;
  bottom: 0;
  height: 2px;
  background: var(--brand);
  transform: scaleX(0);
  transform-origin: left;
  transition: .25s;
}

.nav-link:hover::after,
.nav-link.active::after {
  transform: scaleX(1);
}

.btn-primary {
  background: var(--brand);
  border-color: var(--brand);
}

.btn-outline-primary {
  color: var(--brand);
  border-color: var(--brand);
}

.btn-outline-primary:hover {
  background: var(--brand);
  border-color: var(--brand);
  color: #fff;
}

/* ===== Hero Slider ===== */
.hero-slider .carousel-item {
  position: relative;
}

.object-cover {
  object-fit: cover;
}

.hero-slider .overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, .35), rgba(0, 0, 0, .55));
}

.hero-slider .carousel-caption {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  color: #fff;
  text-shadow: 0 10px 30px rgba(0, 0, 0, .3);
}

/* ===== Sections ===== */
.section-padding {
  padding: 5rem 0;
}

.rounded-bottom-5 {
  border-bottom-left-radius: 2rem;
  border-bottom-right-radius: 2rem;
}

.bg-gradient-light {
  background: linear-gradient(180deg, #f8f9ff, #ffffff);
}

.feature-tile {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: .75rem 1rem;
  background: #f6f7fb;
  border-radius: 1rem;
  border: 1px solid #edf0ff;
}

.feature-tile .tile-icon {
  font-size: 1.25rem;
}

/* Cards hover */
.hover-up {
  transition: transform .25s ease, box-shadow .25s ease;
}

.hover-up:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 30px rgba(0, 0, 0, .08);
}

/* Gallery strip */
.gallery-strip {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 6px;
}

.gallery-strip img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: .75rem;
}

@media (max-width: 991.98px) {
  .gallery-strip {
    grid-template-columns: repeat(3, 1fr);
  }

  body {
    padding-top: 64px;
  }
}

/* ===== Page Hero (shared) ===== */
.page-hero{
  position: relative;
  min-height: 48vh;
  padding: 7rem 0 5rem; /* adjust if your navbar is fixed-top */
  color: #fff;
  overflow: hidden;
}
.page-hero::before{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.55));
  z-index:0;
}
.page-hero .container{ position: relative; z-index: 1; }
.hero-wave{ position:absolute; left:0; right:0; bottom:-1px; height:80px; z-index:1; }
.hero-wave svg{ width:100%; height:100%; display:block; }
.hero-wave path{ fill:#ffffff; } /* match to your page bg, e.g., #f8f9fa if light-gray */

/* Breadcrumb look on dark hero */
.breadcrumb{ --bs-breadcrumb-divider: "›"; margin-bottom: .75rem; }
.breadcrumb .breadcrumb-item a{ color: rgba(255,255,255,.85); text-decoration: none; }
.breadcrumb .breadcrumb-item a:hover{ text-decoration: underline; }
.breadcrumb .breadcrumb-item.active{ color: rgba(255,255,255,.6); }

/* Background images per page (replace with your own assets if needed) */
.page-hero-about{
  background: url("https://images.unsplash.com/photo-1503951914875-452162b0f3f1?q=80&w=2400&auto=format&fit=crop") center/cover no-repeat;
}
.page-hero-gallery{
  background: url("https://images.unsplash.com/photo-1524253482453-3fed8d2fe12b?q=80&w=2400&auto=format&fit=crop") center/cover no-repeat;
}
.page-hero-contact{
  background: url("https://images.unsplash.com/photo-1596462502278-27bfdc403348?q=80&w=2400&auto=format&fit=crop") center/cover no-repeat;
}

/* Small screens */
@media (max-width: 575.98px){
  .page-hero{ min-height: 38vh; padding: 6rem 0 4rem; }
}
/* Generic page hero */
.page-hero {
  position: relative;
  min-height: 48vh;
  padding: 7rem 0 5rem; /* adjust if navbar is fixed-top */
  color: #fff;
  overflow: hidden;
}
.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.55));
  z-index: 0;
}
.page-hero .container { position: relative; z-index: 1; }

/* services hero background */
.page-hero-services {
  background: url("https://images.unsplash.com/photo-1522335789203-aabd1fc54bc9?q=80&w=2400&auto=format&fit=crop") center/cover no-repeat;
}

/* wave at bottom */
.hero-wave {
  position: absolute;
  left: 0; right: 0; bottom: -1px;
  height: 80px; z-index: 1;
}
.hero-wave svg { width: 100%; height: 100%; display: block; }
.hero-wave path { fill: #ffffff; } /* match with your page bg */

/* breadcrumb look */
.breadcrumb { --bs-breadcrumb-divider: "›"; }
.breadcrumb .breadcrumb-item a {
  color: rgba(255,255,255,.85);
  text-decoration: none;
}
.breadcrumb .breadcrumb-item a:hover { text-decoration: underline; }
.breadcrumb .breadcrumb-item.active { color: rgba(255,255,255,.6); }

/* mobile adjustment */
@media (max-width: 575.98px) {
  .page-hero { min-height: 38vh; padding: 6rem 0 4rem; }
}

.footer-neo {
  background: radial-gradient(1200px 600px at 10% -10%, rgba(255, 255, 255, 0.06), transparent),
    radial-gradient(1000px 500px at 100% 0%, rgba(255, 255, 255, 0.04), transparent),
    #0f1120;
}

.footer-neo .footer-top {
  color: #e9eaf3;
}

.footer-divider {
  border-color: rgba(255, 255, 255, .12) !important;
}

.brand-badge {
  width: 36px;
  height: 36px;
  display: inline-grid;
  place-items: center;
  border-radius: 12px;
  font-weight: 700;
  color: #fff;
  background: linear-gradient(135deg, var(--brand, #662d91), #b08cff);
  box-shadow: 0 8px 24px rgba(0, 0, 0, .25), inset 0 0 0 1px rgba(255, 255, 255, .15);
}

.footer-link {
  color: rgba(255, 255, 255, .75);
  text-decoration: none;
}

.footer-link:hover {
  color: #fff;
  text-decoration: underline;
}

.social-pill {
  width: 36px;
  height: 36px;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  text-decoration: none;
  color: #fff;
  background: rgba(255, 255, 255, .12);
  transition: transform .2s ease, background .2s ease;
}

.social-pill:hover {
  transform: translateY(-2px);
  background: var(--brand, #662d91);
}

.footer-neo .btn-outline-light {
  border-color: rgba(255, 255, 255, .35);
  color: #fff;
}

.footer-neo .btn-outline-light:hover {
  background: #fff;
  color: #111;
}




/* Page hero (top banner) */
.page-hero{
  position: relative;
  min-height: 48vh;
  padding: 7rem 0 5rem;
  color: #fff;
  overflow: hidden;
}
.page-hero::before{
  /* dark overlay */
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.55));
  z-index:0;
}
.page-hero .container{ position: relative; z-index: 1; }

/* Salon variant with background image */
.page-hero-salon{
  background: url("https://images.unsplash.com/photo-1522335789203-aabd1fc54bc9?q=80&w=2400&auto=format&fit=crop") center/cover no-repeat;
}

/* Wave at bottom */
.hero-wave{
  position:absolute; left:0; right:0; bottom:-1px; height:80px; z-index:1;
}
.hero-wave svg{ width:100%; height:100%; display:block; }
.hero-wave path{ fill:#ffffff; }  /* page background color */

.breadcrumb{
  --bs-breadcrumb-divider: "›";
}
.breadcrumb .breadcrumb-item a{
  color: rgba(255,255,255,.85); text-decoration: none;
}
.breadcrumb .breadcrumb-item a:hover{ text-decoration: underline; }
.breadcrumb .breadcrumb-item.active{ color: rgba(255,255,255,.6); }

/* small screens */
@media (max-width: 575.98px){
  .page-hero{ min-height: 38vh; padding: 6rem 0 4rem; }
}


/* Floating Buttons Container */
.contact-float {
  position: fixed;
  bottom: 20px;
  right: 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  z-index: 1050;
}

/* Generic button style */
.btn-float {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-size: 22px;
  color: #fff;
  text-decoration: none;
  box-shadow: 0 6px 15px rgba(0,0,0,.25);
  transition: transform .2s ease, box-shadow .2s ease;
}

/* Hover effect */
.btn-float:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(0,0,0,.35);
}

/* Specific colors */
.btn-float.call { background: #0d6efd; }     /* Bootstrap primary blue */
.btn-float.whatsapp { background: #25D366; } /* Official WhatsApp green */

.offcanvas {
  height: 100% !important;  /* ensure full height */
}
@media (max-width: 768px) {
  header.hero-slider {
    padding: 0 !important;
    margin: 0 !important;
  }

  .carousel-inner,
  .carousel-item,
  .carousel-item img {
    height: auto !important;
    max-height: 100% !important;
    width: 100% !important;
    object-fit: cover;
    margin-top: 14px !important;
  }
}
