/* ===== ROOT & RESET ===== */
:root {
  --lavender:       #9b7fe8;
  --lavender-light: #c9b8f5;
  --lavender-pale:  #ede8fb;
  --lavender-ultra: #f5f2ff;
  --lavender-deep:  #7c5cbf;
  --lavender-dark:  #4a2f9b;
  --white:          #ffffff;
  --text-dark:      #1a1228;
  --text-mid:       #4a4260;
  --text-light:     #8e85aa;
  --shadow:         0 8px 40px rgba(155,127,232,0.18);
  --shadow-strong:  0 20px 60px rgba(155,127,232,0.28);
  --radius:         20px;
  --radius-sm:      12px;
  --transition:     0.4s cubic-bezier(0.4,0,0.2,1);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html  { scroll-behavior:smooth; }
body  { font-family:'DM Sans',sans-serif; background:var(--white); color:var(--text-dark);overflow-x:hidden; line-height:1.7; }
img   { max-width:100%; display:block; }
a     { text-decoration:none; color:inherit; }
ul    { list-style:none; }

.container { max-width:1200px; margin:0 auto; padding:0 2rem; }
.section   { padding:100px 0; }

/* ===== TYPOGRAPHY ===== */
.section-label {
  font-size:0.78rem; font-weight:600; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--lavender);
  margin-bottom:0.75rem;
  display:flex; align-items:center; gap:0.6rem;
}
.section-label::before {
  content:''; width:32px; height:2px;
  background:var(--lavender); display:inline-block;
}
.section-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.2rem,4vw,3.2rem);
  font-weight:700; line-height:1.15;
  color:var(--text-dark); margin-bottom:1.2rem;
}
.section-title em { font-style:italic; color:var(--lavender); }
.section-title.centered,
.section-sub.centered { text-align:center; }
.section-sub {
  font-size:1.05rem; color:var(--text-mid);
  max-width:560px; margin:0 auto 3rem;
}

/* ===== BUTTONS ===== */
.btn-primary {
  display:inline-flex; align-items:center; gap:0.5rem;
  padding:0.85rem 2rem;
  background:linear-gradient(135deg,var(--lavender),var(--lavender-deep));
  color:white; border-radius:50px;
  font-weight:600; font-size:0.95rem;
  border:none; cursor:pointer;
  transition:var(--transition);
  box-shadow:0 4px 20px rgba(155,127,232,0.4);
}
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 8px 30px rgba(155,127,232,0.55); }
.btn-primary.full-width { width:100%; justify-content:center; }

.btn-ghost {
  display:inline-flex; align-items:center; gap:0.5rem;
  padding:0.85rem 2rem; background:transparent;
  color:var(--lavender-deep); border:2px solid var(--lavender);
  border-radius:50px; font-weight:600; font-size:0.95rem;
  cursor:pointer; transition:var(--transition);
}
.btn-ghost:hover { background:var(--lavender-pale); transform:translateY(-3px); }

/* ===== NAVBAR ===== */
.navbar {
  position:fixed; top:0; left:0; right:0;
  z-index:1000; padding:1rem 0;
  transition:var(--transition);
}
.navbar.scrolled {
  background:rgba(255,255,255,0.96);
  backdrop-filter:blur(20px);
  box-shadow:0 2px 30px rgba(155,127,232,0.13);
  padding:0.65rem 0;
}
.nav-container {
  max-width:1200px; margin:0 auto; padding:0 2rem;
  display:flex; align-items:center; justify-content:space-between;
}

/* Logo — image + text */
.nav-logo {
  display:flex; align-items:center; gap:0.65rem;
}
.logo-img {
  width:70px; height:70px;
  border-radius:12px;
  object-fit:cover;
  box-shadow:0 4px 14px rgba(155,127,232,0.35);
  transition:transform 0.35s, box-shadow 0.35s;
  flex-shrink:0;
}
.nav-logo:hover .logo-img {
  transform:rotate(-6deg) scale(1.08);
  box-shadow:0 8px 22px rgba(155,127,232,0.5);
}
.logo-text {
  font-family:'Cormorant Garamond',serif;
  font-size:1.65rem; font-weight:700;
  color:var(--lavender-dark); letter-spacing:0.02em;
}
/* Logo text white on transparent navbar (hero section) */
.navbar:not(.scrolled) .logo-text { color:#fff; }
.navbar:not(.scrolled) .logo-img  { box-shadow:0 4px 14px rgba(0,0,0,0.35); }

/* Nav links */
.nav-links {
  display:flex; align-items:center; gap:2.2rem;
}
.nav-link {
  font-size:0.92rem; font-weight:500;
  color:var(--text-mid); position:relative;
  transition:color 0.3s;
}
.navbar:not(.scrolled) .nav-link { color:rgba(255,255,255,0.88); }
.nav-link::after {
  content:''; position:absolute; bottom:-4px; left:0;
  width:0; height:2px; background:var(--lavender);
  transition:width 0.3s; border-radius:2px;
}
.nav-link:hover,
.nav-link.active { color:var(--lavender); }
.navbar:not(.scrolled) .nav-link:hover,
.navbar:not(.scrolled) .nav-link.active { color:#fff; }
.nav-link:hover::after,
.nav-link.active::after { width:100%; }

.nav-cta {
  background:linear-gradient(135deg,var(--lavender),var(--lavender-deep)) !important;
  color:white !important;
  padding:0.6rem 1.4rem; border-radius:50px;
  box-shadow:0 4px 16px rgba(155,127,232,0.4);
}
.nav-cta::after { display:none; }
.nav-cta:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(155,127,232,0.5); }

.hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:4px;
}
.hamburger span {
  display:block; width:24px; height:2px;
  background:var(--lavender-dark); border-radius:2px;
  transition:var(--transition);
}
.navbar:not(.scrolled) .hamburger span { background:#fff; }

/* ===== HERO — IMAGE SLIDES ===== */
.hero {
  position:relative; height:100vh;
  min-height:680px; overflow:hidden;
}
.hero-slider { width:100%; height:100%; position:relative; }

.slide {
  position:absolute; inset:0;
  display:flex; align-items:center;
  opacity:0; pointer-events:none;
  transition:opacity 1s ease;
}
.slide.active { opacity:1; pointer-events:auto; }

/* Full-bleed background image */
.slide-img-wrap {
  position:absolute; inset:0;
  overflow:hidden;
}
.slide-img {
  width:100%; height:100%;
  object-fit:cover; object-position:center;
  transform:scale(1.06);
  transition:transform 6s ease;
  filter:brightness(0.78);
}
.slide.active .slide-img { transform:scale(1); }

/* Lavender tinted overlay */
.slide-overlay {
  position:absolute; inset:0;
  background:linear-gradient(
    120deg,
    rgba(74,47,155,0.72) 0%,
    rgba(155,127,232,0.45) 55%,
    rgba(0,0,0,0.15) 100%
  );
}

/* Content panel */
.slide-content {
  position:relative; z-index:2;
  max-width:680px;
  padding:0 0 0 calc((100% - 1200px)/2 + 2rem);
  animation:slideUp 0.9s 0.15s both;
}
.slide:not(.active) .slide-content { animation:none; }
@keyframes slideUp {
  from { opacity:0; transform:translateY(48px); }
  to   { opacity:1; transform:translateY(0); }
}

.slide-tag {
  display:inline-flex; align-items:center; gap:0.5rem;
  font-size:0.78rem; font-weight:600;
  letter-spacing:0.14em; text-transform:uppercase;
  color:#fff;
  background:rgba(255,255,255,0.18);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,0.3);
  padding:0.45rem 1.1rem; border-radius:50px;
  margin-bottom:1.4rem;
}
.slide-tag i { color:var(--lavender-light); }

.slide-title {
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.8rem,5.5vw,4.6rem);
  font-weight:700; line-height:1.1;
  color:#fff; margin-bottom:1.2rem;
}
.slide-title em {
  font-style:italic;
  color:var(--lavender-light);
}

.slide-sub {
  font-size:1.08rem; color:rgba(255,255,255,0.85);
  max-width:500px; margin-bottom:2rem; line-height:1.75;
}
.slide-btns { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:2rem; }

/* Slide badges */
.slide-badges { display:flex; gap:1rem; flex-wrap:wrap; }
.slide-badge {
  display:flex; align-items:center; gap:0.55rem;
  background:rgba(255,255,255,0.14);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.25);
  color:#fff; border-radius:50px;
  padding:0.45rem 1.1rem;
  font-size:0.82rem; font-weight:600;
  animation:badgeFloat 4s ease-in-out infinite;
}
.slide-badge:nth-child(2) { animation-delay:0.6s; }
.slide-badge i { color:var(--lavender-light); font-size:0.9rem; }
@keyframes badgeFloat {
  0%,100% { transform:translateY(0); }
  50%      { transform:translateY(-6px); }
}

/* Slide progress counter */
.slide-counter {
  position:absolute; top:50%; right:2.5rem;
  transform:translateY(-50%);
  display:flex; flex-direction:column;
  align-items:center; gap:0.5rem;
  z-index:10;
}
.slide-counter span {
  font-size:0.82rem; font-weight:700;
  color:rgba(255,255,255,0.75);
  font-variant-numeric:tabular-nums;
}
.counter-bar {
  width:2px; height:80px;
  background:rgba(255,255,255,0.25);
  border-radius:2px; overflow:hidden;
}
.counter-fill {
  width:100%; background:var(--lavender-light);
  border-radius:2px;
  transition:height 5s linear;
}

/* Hero controls */
.hero-controls {
  position:absolute; bottom:2.5rem; left:50%;
  transform:translateX(-50%);
  display:flex; align-items:center; gap:1rem; z-index:10;
}
.hero-prev, .hero-next {
  width:44px; height:44px; border-radius:50%;
  background:rgba(255,255,255,0.18);
  backdrop-filter:blur(8px);
  border:2px solid rgba(255,255,255,0.35);
  color:#fff; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  font-size:0.85rem;
  transition:var(--transition);
}
.hero-prev:hover, .hero-next:hover {
  background:var(--lavender); border-color:var(--lavender);
  transform:scale(1.1);
}
.hero-dots { display:flex; gap:0.5rem; }
.dot {
  width:8px; height:8px; border-radius:50%;
  background:rgba(255,255,255,0.4); cursor:pointer;
  transition:var(--transition);
}
.dot.active {
  background:#fff; width:28px; border-radius:4px;
}

/* Scroll hint */
.hero-scroll-hint {
  position:absolute; right:2.5rem; bottom:3rem;
  display:flex; flex-direction:column;
  align-items:center; gap:0.6rem; z-index:10;
}
.hero-scroll-hint span {
  font-size:0.7rem; font-weight:600;
  letter-spacing:0.14em; text-transform:uppercase;
  color:rgba(255,255,255,0.6); writing-mode:vertical-rl;
}
.scroll-line {
  width:2px; height:50px;
  background:linear-gradient(to bottom,rgba(255,255,255,0.7),transparent);
  animation:scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine {
  0%   { transform:scaleY(0); transform-origin:top; }
  50%  { transform:scaleY(1); transform-origin:top; }
  51%  { transform:scaleY(1); transform-origin:bottom; }
  100% { transform:scaleY(0); transform-origin:bottom; }
}

/* ===== ABOUT ===== */
.about { background:var(--white); }
.about-grid {
  display:grid; grid-template-columns:1fr 1fr;
  gap:5rem; align-items:center;
}
.about-text p { color:var(--text-mid); margin-bottom:1.2rem; font-size:1.02rem; text-align: justify; }
.about-stats { display:flex; gap:2.5rem; margin:2rem 0 2.5rem; }
.stat { display:flex; flex-direction:column; }
.stat-row { display:flex; align-items:baseline; gap:2px; }
.stat-num {
  font-family:'Cormorant Garamond',serif;
  font-size:2.6rem; font-weight:700; color:var(--lavender); line-height:1;
}
.stat-plus { font-size:1.6rem; color:var(--lavender); font-weight:700; }
.stat-label { font-size:0.82rem; color:var(--text-light); margin-top:0.2rem; font-weight:500; }

.about-images { position:relative; }
.img-stack    { position:relative; height:480px; }
.img-card     { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-strong); position:absolute; }
.img-main     {
  width:360px; height:380px; top:0; right:0;
  animation:imgFloat 6s ease-in-out infinite;
}
.img-main img    { width:100%; height:100%; object-fit:cover; }
.img-secondary   {
  width:240px; height:240px; bottom:0; left:0;
  border:6px solid white;
  animation:imgFloat 5s 1s ease-in-out infinite;
}
.img-secondary img { width:100%; height:100%; object-fit:cover; }
@keyframes imgFloat {
  0%,100% { transform:translateY(0); }
  50%     { transform:translateY(-10px); }
}
.img-badge {
  position:absolute; top:50%; right:-20px;
  transform:translateY(-50%);
  background:linear-gradient(135deg,var(--lavender),var(--lavender-deep));
  color:white; border-radius:var(--radius-sm);
  padding:1rem 1.2rem;
  display:flex; align-items:center; gap:0.7rem;
  box-shadow:0 8px 30px rgba(155,127,232,0.35);
  font-size:0.85rem; font-weight:600; line-height:1.4; z-index:3;
}
.img-badge i { font-size:1.4rem; }

/* ===== SERVICES — FLIP + SCALE ENLARGE ===== */
/* Container for the grid */
.cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 30px;
  padding: 30px;
  gap: 24px; 
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 20px;
  box-sizing: border-box;
}

/* Card Container */
.flip-card {
  position: relative;
  height: 450px; /* Fixed height for consistency */
  cursor: pointer;
  background: transparent;
}
.service-icon-wrap i{
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 150px;
  color: var(--lavender);
  margin-bottom: 30px;
}

.flip-back p{
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 1rem;
  font-weight: 700;
  text-align: justify;
  color: white;
  margin-bottom: 20px;
}


.flip-front{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding: 25px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  transition: opacity 0.4s ease-in-out;
  border: 3px solid white;
  border-radius: 12px;
  background: #e8e7eb;
  box-shadow: 0 4px 10px rgba(0,0,0,0.05);
}
.flip-back {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding: 25px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  transition: opacity 0.4s ease-in-out;
  border: 1px solid #eee;
  border-radius: 12px;
  background: #8e85aa;
  box-shadow: 0 4px 10px rgba(0,0,0,0.05);
}

/* Initially hide the back */
.flip-back {
  opacity: 0;
  pointer-events: none;
}

/* On hover: Swap */
.flip-card:hover .flip-front {
  opacity: 0;
}

.flip-card:hover .flip-back {
  opacity: 1;
  pointer-events: auto;
}
/* ===== TESTIMONIALS ===== */
.testimonials { background:var(--white); }
.testimonials-grid {
  display:grid; grid-template-columns:repeat(2,1fr); gap:2rem;
}
.testi-card {
  background:var(--lavender-ultra);
  border-radius:var(--radius); padding:2rem;
  position:relative; overflow:hidden;
  border:1px solid var(--lavender-pale);
  transition:var(--transition);
}
.testi-card::before {
  content:''; position:absolute; top:0; left:0; right:0;
  height:3px;
  background:linear-gradient(90deg,var(--lavender),var(--lavender-light));
  transform:scaleX(0); transition:transform 0.4s;
}
.testi-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-strong); }
.testi-card:hover::before { transform:scaleX(1); }
.testi-stars { color:#f0a500; font-size:0.85rem; margin-bottom:1rem; display:flex; gap:2px; }
.testi-card > p {
  font-size:0.95rem; color:var(--text-mid);
  line-height:1.8; font-style:italic; margin-bottom:1.5rem;
}
.testi-author { display:flex; align-items:center; gap:1rem; }
.testi-author img {
  width:52px; height:52px; border-radius:50%; object-fit:cover;
  border:3px solid var(--lavender-light);
}
.testi-author strong { display:block; font-size:0.92rem; color:var(--text-dark); }
.testi-author span  { font-size:0.8rem; color:var(--text-light); }
.testi-quote {
  position:absolute; bottom:1.5rem; right:1.5rem;
  font-size:2rem; color:var(--lavender-pale);
}

/* ===== MARQUEE ===== */
.marquee-section {
  padding:2.5rem 0;
  background:linear-gradient(135deg,var(--lavender-ultra),var(--lavender-pale));
  overflow:hidden;
}
.marquee-label {
  text-align:center; font-size:1.5rem; font-weight:600;
  letter-spacing:0.15em; text-transform:uppercase;
  color:var(--text-light); margin-bottom:1.5rem;
}
.marquee-track { overflow:hidden; position:relative; }
.marquee-track::before,
.marquee-track::after {
  content:''; position:absolute; top:0; bottom:0; width:120px; z-index:2;
}
.marquee-track::before { left:0;  background:linear-gradient(to right, var(--lavender-ultra),transparent); }
.marquee-track::after  { right:0; background:linear-gradient(to left,  var(--lavender-pale), transparent); }
.marquee-inner {
  display:flex; gap:1.5rem;
  animation:marqueeScroll 28s linear infinite;
  width:max-content;
}
.marquee-inner:hover { animation-play-state:paused; }
@keyframes marqueeScroll {
  from { transform:translateX(0); }
  to   { transform:translateX(-50%); }
}

.marquee-item {
  flex-shrink: 0;
  width: 180px;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 8px solid var(--lavender-light);
  border-radius: 8px;
  filter: grayscale(1);
  transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
  background: #f7f7f7;
}

.marquee-item:hover {
  filter: grayscale(0);
  border: 4px solid var(--lavender-dark);
  box-shadow: var(--lavender);
  transform: translateY(-3px);
}



/* ===== CONTACT ===== */
.contact { background:var(--lavender-ultra); }
.contact-grid {
  display:grid; grid-template-columns:1fr 1.4fr;
  gap:4rem; align-items:start;
}
.contact-info { display:flex; flex-direction:column; gap:1.8rem; }
.contact-item { display:flex; align-items:flex-start; gap:1.2rem; }
.ci-icon {
  width:50px; height:50px;
  background:linear-gradient(135deg,var(--lavender),var(--lavender-deep));
  border-radius:14px; display:flex; align-items:center; justify-content:center;
  color:white; font-size:1.05rem; flex-shrink:0;
}
.contact-item strong { display:block; font-size:0.9rem; color:var(--text-dark); margin-bottom:0.2rem; }
.contact-item p      { font-size:0.9rem; color:var(--text-mid); line-height:1.6; }
.contact-form {
  background:white; border-radius:var(--radius);
  padding:2.5rem; box-shadow:var(--shadow);
}
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { margin-bottom:1.2rem; }
.form-group label {
  display:block; font-size:0.85rem; font-weight:600;
  color:var(--text-mid); margin-bottom:0.5rem;
}
.form-group input,
.form-group textarea {
  width:100%; padding:0.85rem 1rem;
  border:1.5px solid var(--lavender-pale);
  border-radius:var(--radius-sm);
  font-family:inherit; font-size:0.95rem;
  color:var(--text-dark); background:var(--lavender-ultra);
  transition:border-color 0.3s, box-shadow 0.3s; outline:none;
}
.form-group input:focus,
.form-group textarea:focus {
  border-color:var(--lavender);
  box-shadow:0 0 0 3px rgba(155,127,232,0.12);
  background:white;
}
.form-group textarea { resize:vertical; }

/* ===== WORLD MAP ===== */
.worldmap-section { padding:100px 0; background:white; }
.map-wrapper { position:relative; margin-top:3rem; }

.world-map {
    width: 100%; 
    height: 600px; 
    display: block;
    mix-blend-mode: multiply;
    filter: contrast(1.2);
  
}
/* .map-glow {
  position:absolute; inset:-40px;
  background:radial-gradient(ellipse at 50% 50%,rgba(155,127,232,0.08) 0%,transparent 70%);
  pointer-events:none;
}
.world-map-svg {
  width:100%; max-width:960px; margin:0 auto; display:block;
  background:linear-gradient(135deg,#f8f4ff,#ede8fb);
  border-radius:var(--radius);
  box-shadow:var(--shadow-strong);
  border:1px solid var(--lavender-pale);
}
.map-pin  { animation:mapPinPulse 2s ease-in-out infinite; }
.map-pulse{ animation:mapPulseRing 2s ease-out infinite; }
@keyframes mapPinPulse  { 0%,100%{ transform:scale(1); } 50%{ transform:scale(1.2); } }
@keyframes mapPulseRing { 0%{ r:6; opacity:1; } 100%{ r:24; opacity:0; } }
.map-stats {
  display:flex; justify-content:center; gap:4rem; margin-top:2.5rem;
}
.map-stat { text-align:center; }
.map-stat span {
  font-family:'Cormorant Garamond',serif;
  font-size:2.5rem; font-weight:700; color:var(--lavender); display:block;
}
.map-stat p { font-size:0.85rem; color:var(--text-light); font-weight:500; } */

/* ===== FOOTER ===== */
.footer { background:#7c5cbf; color:rgba(255,255,255,0.7); }
.footer-top { padding:5rem 0 3rem; }
.footer-grid {
  display:grid; grid-template-columns:1.8fr 1fr 1.4fr; gap:3rem;
}
.footer-logo-wrap { display:flex; align-items:center; gap:0.65rem; margin-bottom:1rem; }
.footer-logo-wrap .logo-img {
  width:42px; height:42px; border-radius:10px;
  box-shadow:0 4px 14px rgba(155,127,232,0.4);
}
.footer-about {
  font-size:0.9rem; line-height:1.8; font-weight: bolder;
  margin:0.5rem 0 1.5rem; max-width:280px;
}
.footer-socials { display:flex; gap:0.8rem; }
.footer-socials a {
  width:38px; height:38px; background:rgba(255,255,255,0.08);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; color:rgba(255,255,255,0.6);
  transition:var(--transition); 
}
.footer-socials a:hover { background:var(--lavender); color:white; transform:translateY(-3px); }
.footer-col h4 {
  font-family:'Cormorant Garamond',serif;
  font-size:1.2rem; font-weight:700; color:white; margin-bottom:1.2rem;
}
.footer-col ul li { margin-bottom:0.7rem; font-weight: bolder;}
.footer-col ul li a {
  font-size:0.9rem; color:rgba(255,255,255,0.6);
  display:flex; align-items:center; gap:0.45rem;
  transition:color 0.3s;
}
.footer-col ul li a i { font-size:0.65rem; color:var(--lavender-light); font-weight: bolder;}
.footer-col ul li a:hover { color:var(--lavender-light); }
.footer-col address { font-style:normal; font-weight: bolder;}
.footer-col address p {
  font-size:0.88rem; color:rgba(255,255,255,0.6);
  margin-bottom:0.8rem; display:flex;
  align-items:flex-start; gap:0.7rem; line-height:1.6;
}
.footer-col address i { color:var(--lavender-light); margin-top:3px; flex-shrink:0; }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,0.08); padding:1.5rem 0;
}
.footer-bottom .container {
  display:flex; align-items:center; justify-content:space-between;
  flex-wrap:wrap; gap:0.5rem;
}
.footer-bottom p   { font-size:0.85rem; color:rgba(255,255,255,0.4); }
.footer-bottom a   { color:rgba(255,255,255,0.5); transition:color 0.3s; }
.footer-bottom a:hover { color:var(--lavender-light); }
.footer-bottom i.fa-heart { color:var(--lavender); }

/* ===== WHATSAPP FLOAT ===== */
.whatsapp-float {
  position:fixed; bottom:2rem; right:2rem; z-index:999;
  width:58px; height:58px; background:#25d366;
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  color:white; font-size:1.6rem;
  box-shadow:0 6px 24px rgba(37,211,102,0.4);
  transition:var(--transition);
  animation:waBounce 2.5s ease-in-out infinite;
}
.whatsapp-float:hover {
  transform:scale(1.12);
  box-shadow:0 10px 36px rgba(37,211,102,0.55);
  animation:none;
}
@keyframes waBounce {
  0%,100% { transform:translateY(0); }
  50%     { transform:translateY(-8px); }
}
.wa-tooltip {
  position:absolute; right:72px;
  background:white; color:var(--text-dark);
  font-size:0.82rem; font-weight:600;
  padding:0.45rem 1rem; border-radius:50px;
  box-shadow:0 4px 16px rgba(0,0,0,0.12);
  white-space:nowrap; opacity:0; pointer-events:none;
  transform:translateX(10px); transition:var(--transition);
}
.whatsapp-float:hover .wa-tooltip { opacity:1; transform:translateX(0); }

/* ===== BACK TO TOP ===== */
.back-to-top {
  position:fixed; bottom:6.5rem; right:2rem; z-index:999;
  width:42px; height:42px; background:white;
  border:2px solid var(--lavender-light); border-radius:50%;
  color:var(--lavender); font-size:0.9rem;
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 16px rgba(155,127,232,0.2);
  opacity:0; pointer-events:none; transition:var(--transition);
}
.back-to-top.visible { opacity:1; pointer-events:auto; }
.back-to-top:hover { background:var(--lavender); color:white; transform:translateY(-3px); }

/* ===== REVEAL ===== */
.reveal {
  opacity:0; transform:translateY(40px);
  transition:opacity 0.8s ease, transform 0.8s ease;
}
.reveal.visible { opacity:1; transform:translateY(0); }

/* ===== RESPONSIVE ===== */
@media (max-width:1024px) {
  .services-grid { grid-template-columns:repeat(2,1fr); }
  .about-grid    { gap:3rem; }
  .footer-grid   { grid-template-columns:1fr 1fr; gap:2rem; }
  .slide-content { padding:0 2rem; }
}

@media (max-width:768px) {
  .nav-links {
    display:none; flex-direction:column;
    position:fixed; top:0; right:0;
    width:80%; max-width:300px; height:100vh;
    background:white; padding:5rem 2rem 2rem;
    gap:1.5rem; box-shadow:-10px 0 40px rgba(0,0,0,0.1);
    z-index:999; transform:translateX(100%);
    transition:transform 0.4s ease;
  }
  .nav-links.open { display:flex; transform:translateX(0); }
  .nav-links .nav-link { color:var(--text-mid) !important; }
  .hamburger { display:flex; z-index:1001; }
  .services-grid   { grid-template-columns:1fr; }
  .testimonials-grid { grid-template-columns:1fr; }
  .about-grid      { grid-template-columns:1fr; }
  .contact-grid    { grid-template-columns:1fr; }
  .form-row        { grid-template-columns:1fr; }
  .footer-grid     { grid-template-columns:1fr; }
  .about-images    { height:480px; }
  .img-main        { width:260px; height:280px; }
  .img-secondary   { width:180px; height:180px; }
  .img-badge       { right:0; }
  .about-stats     { flex-wrap:wrap; gap:1.5rem; }
  .section         { padding:70px 0; }
  .map-stats       { gap:2rem; flex-wrap:wrap; }
  .footer-bottom .container { flex-direction:column; text-align:center; }
  .hero-scroll-hint { display:none; }
  .slide-counter    { display:none; }
  .slide-title      { font-size:2.4rem; }
  .flip-card        { height:450px; }
  /* Remove scale on mobile — too disruptive */
  .flip-card:hover  { transform:scale(1.03); }
}

@media (max-width:480px) {
  .slide-btns   { flex-direction:column; }
  .slide-badges { flex-direction:column; }
  .hero-controls{ bottom:1.5rem; }
  .map-stats    { gap:1.5rem; }
  .marquee-logo { padding:0.6rem 1rem; font-size:0.82rem; }
}
.created-by i { font-size: 12px; color: #402f75; }
.created-by a { font-weight: 700; font-size: 7px; color: #e8f5e9; }
.created-by a:hover {
  color: #4a2f9b;
  border-bottom: 1px solid #4a2f9b;
  font-size: 14px;
}
