:root{
  --bg:#0b1220;
  --bg2:#101a33;
  --card:rgba(255,255,255,.06);
  --stroke:rgba(255,255,255,.14);

  --text:#eaf0ff;
  --muted:rgba(234,240,255,.75);

  --accent:#ff3d86;   /* wedding-luxury magenta */
  --gold:#f7d774;     /* champagne */
  --jade:#22d3b6;     /* premium */
  --coral:#ff6f61;
  --shadow: 0 18px 60px rgba(0,0,0,.45);

  --r:22px;
}

.reelThumb{
  width:100%;
  aspect-ratio:9 / 16;
  overflow:hidden;
  border-radius:18px 18px 0 0;
}

.reelThumb video{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}


/* Floating Social Media Bar */
.floating-social{
  position: fixed;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.social-btn{
  width: 46px;
  height: 46px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 12px;
  color: #fff;
  text-decoration: none;
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.15);
  box-shadow: 0 10px 30px rgba(0,0,0,.3);
  transition: transform .2s, box-shadow .2s;
}

.social-btn:hover{
  transform: translateY(-4px) scale(1.08);
  box-shadow: 0 18px 45px rgba(0,0,0,.45);
}

/* Platform Colors */
.insta{
  background: linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888);
}
.fb{
  background: linear-gradient(135deg,#1877f2,#0a58ca);
}
.yt{
  background: linear-gradient(135deg,#ff0000,#b30000);
}

/* Mobile Adjustment */
@media (max-width: 640px){
  .floating-social{
    right: 10px;
  }
}




/* ---------- Animated Icon System (No overlap) ---------- */

/* card needs position for better visuals */
.cards .card{
  position: relative;
  overflow: hidden;
}

/* Lane keeps icon ABOVE heading, with space reserved */
.iconLane{
  position: relative;
  height: 84px;                /* reserved space so it never overlaps */
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 8px 6px;
}

/* Icon bubble (colorful, premium) */
.iconBubble{
  width: 64px;
  height: 64px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 18px 55px rgba(0,0,0,.24);
  border: 1px solid rgba(255,255,255,.22);
  backdrop-filter: blur(10px);
  position: relative;

  /* Movement left -> right -> left (loop) */
  animation: laneMove 6.8s ease-in-out infinite;

  /* GPU smooth */
  transform: translate3d(0,0,0);
  will-change: transform;
}

/* each card different timings for variety */
.cards .card:nth-child(2) .iconBubble{ animation-duration: 7.7s; }
.cards .card:nth-child(3) .iconBubble{ animation-duration: 6.1s; }
#services .card:nth-child(1) .iconBubble{ animation-duration: 7.3s; }
#services .card:nth-child(2) .iconBubble{ animation-duration: 6.6s; }
#services .card:nth-child(3) .iconBubble{ animation-duration: 8.2s; }

/* lane move: left -> right -> left */
@keyframes laneMove{
  0%   { transform: translateX(0) rotate(-4deg); }
  50%  { transform: translateX(calc(100% - 64px)) rotate(4deg); }
  100% { transform: translateX(0) rotate(-4deg); }
}

/* Icon self animation: pulse + float */
.iconBubble svg{
  width: 30px;
  height: 30px;
  fill: rgba(255,255,255,.95);
  filter: drop-shadow(0 10px 16px rgba(0,0,0,.25));
  animation: iconPulse 1.9s ease-in-out infinite;
}

@keyframes iconPulse{
  0%,100% { transform: scale(1) rotate(0deg); }
  50%     { transform: scale(1.18) rotate(6deg); }
}

/* Shine sweep on icon */
.iconShine{
  position: absolute;
  inset: 0;
  border-radius: 18px;
  background: linear-gradient(
    120deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,.35) 35%,
    rgba(255,255,255,0) 70%
  );
  transform: translateX(-120%);
  animation: shineSweep 3.4s ease-in-out infinite;
  pointer-events: none;
}

@keyframes shineSweep{
  0%   { transform: translateX(-120%); opacity: .0; }
  20%  { opacity: .35; }
  60%  { opacity: .18; }
  100% { transform: translateX(120%); opacity: 0; }
}

/* Colorful premium gradients */
.icon--decor{  background: linear-gradient(135deg,#ff4d6d,#ff9f1c,#ffd166); }
.icon--stage{  background: linear-gradient(135deg,#7c3aed,#22d3ee,#60a5fa); }
.icon--flow{   background: linear-gradient(135deg,#10b981,#34d399,#a7f3d0); }
.icon--corp{   background: linear-gradient(135deg,#2563eb,#06b6d4,#93c5fd); }
.icon--fashion{background: linear-gradient(135deg,#ec4899,#f97316,#fde047); }
.icon--music{  background: linear-gradient(135deg,#ef4444,#f59e0b,#fde68a); }

/* card list */
.cardList{
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
}
.cardList li{
  font-size: 14px;
  margin: 6px 0;
  opacity: .88;
}

/* Mobile adjustments */
@media (max-width: 520px){
  .iconLane{ height: 78px; }
  .iconBubble{ width: 58px; height: 58px; border-radius: 16px; }
  .iconBubble svg{ width: 28px; height: 28px; }
  @keyframes laneMove{
    0%   { transform: translateX(0) rotate(-4deg); }
    50%  { transform: translateX(calc(100% - 58px)) rotate(4deg); }
    100% { transform: translateX(0) rotate(-4deg); }
  }
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce){
  .iconBubble, .iconBubble svg, .iconShine{ animation: none !important; }
}



*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Montserrat,system-ui,-apple-system,Segoe UI,Arial;
  color:var(--text);
  background: radial-gradient(1200px 900px at 15% 0%, #1b2a55 0%, var(--bg) 45%, #070b14 100%);
  overflow-x:hidden;
}
.wrap{max-width:1180px;margin:0 auto;padding:0 18px}
a{color:inherit}
code{background:rgba(255,255,255,.08);padding:2px 6px;border-radius:8px}

#bg3d{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.25}

.topbar{
  position:sticky;top:0;z-index:50;
  backdrop-filter: blur(12px);
  background: linear-gradient(180deg, rgba(11,18,32,.85), rgba(11,18,32,.45));
  border-bottom:1px solid rgba(255,255,255,.08);
}
.topbar__inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 0;
  gap:14px;
}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand__img{width:46px;height:46px;border-radius:16px;object-fit:contain;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12)}
.brand__logo{
  width:46px;height:46px;border-radius:16px;display:grid;place-items:center;
  font-weight:900;background:linear-gradient(135deg,var(--accent),var(--gold),var(--jade));
  color:#0b1220;box-shadow:0 10px 30px rgba(255,61,134,.18)
}
.brand__name{font-weight:900;font-size:16px;letter-spacing:.3px}
.brand__name span{color:var(--gold)}
.brand__tag{font-size:12px;color:var(--muted);margin-top:2px}

.topbar__actions{display:flex;gap:10px;align-items:center}

/* Floating actions fixed bottom-right */
.floating-actions{
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: flex-end;

  /* luxury feel */
  padding: 10px;
  border-radius: 18px;
  background: rgba(11,18,32,.45);
  border: 1px solid rgba(255,255,255,.10);
  backdrop-filter: blur(10px);
  box-shadow: 0 18px 55px rgba(0,0,0,.35);
}

/* Slightly bigger buttons for mobile thumb */
.floating-actions .chipLink{
  font-size: 13px;
  padding: 12px 14px;
}

/* Keep it clean on very small screens */
@media (max-width: 420px){
  .floating-actions{
    right: 10px;
    bottom: 10px;
    padding: 8px;
  }
  .floating-actions .chipLink{
    font-size: 12px;
    padding: 11px 12px;
  }
}

.chipLink{
  text-decoration:none;
  padding:10px 12px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  font-weight:800;font-size:12px;
  transition:transform .18s, background .18s;
}
.chipLink:hover{transform:translateY(-1px)}
.chipLink--accent{
  border-color:rgba(247,215,116,.35);
  background:linear-gradient(135deg, rgba(255,61,134,.22), rgba(247,215,116,.14));
}

.nav{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.nav__link{
  text-decoration:none;
  font-weight:700;font-size:13px;
  color:rgba(234,240,255,.86);
  padding:10px 12px;border-radius:999px;
  transition:transform .18s, background .18s, color .18s;
}
.nav__link:hover{background:rgba(255,255,255,.08);transform:translateY(-1px)}
.nav__link.active{
  background:linear-gradient(135deg, rgba(255,61,134,.22), rgba(247,215,116,.15));
  border:1px solid rgba(247,215,116,.25);
  color:#fff;
}

.navbtn{
  display:none;
  width:46px;height:46px;border-radius:16px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
}
.navbtn span{display:block;width:20px;height:2px;background:#fff;margin:5px auto;border-radius:2px}

.hero{position:relative;padding:70px 0 40px;min-height:92vh;overflow:hidden}
.hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:22px;align-items:start}
.pill{
  display:inline-flex;padding:10px 14px;border-radius:999px;
  border:1px solid rgba(247,215,116,.28);
  background:rgba(255,255,255,.05);
  color:rgba(247,215,116,.92);
  font-weight:900;font-size:12px;
}
.hero__title{font-size:44px;line-height:1.05;margin:18px 0 10px;letter-spacing:-.8px}
.shine{
  background:linear-gradient(135deg,var(--gold),#fff,var(--jade));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.accent{color:var(--accent)}
.hero__sub{color:var(--muted);font-size:15px;max-width:640px;margin:12px 0 24px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:12px 18px;border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  text-decoration:none;font-weight:900;
  transition:transform .18s, box-shadow .18s, background .18s;
  will-change:transform;
}
.btn--primary{
  background:linear-gradient(135deg, rgba(255,61,134,.95), rgba(247,215,116,.92), rgba(34,211,182,.85));
  color:#0b1220;border:none;box-shadow:0 18px 55px rgba(255,61,134,.18)
}
.btn--ghost{background:rgba(255,255,255,.06);color:#fff}
.btn:hover{transform:translateY(-2px) scale(1.02);box-shadow:var(--shadow)}

.hero__cta{display:flex;gap:12px;flex-wrap:wrap}

.trustRow{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:22px}
.trust{
  padding:14px;border-radius:18px;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
}
.trust__t{font-weight:900;color:var(--gold);font-size:13px}
.trust__s{color:var(--muted);font-size:12px;margin-top:4px}

.heroCard{
  border-radius:var(--r);
  background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.14);
  box-shadow:var(--shadow);
  padding:18px;position:relative;overflow:hidden;
}
.heroGlow{
  position:absolute;inset:-2px;
  background:
    radial-gradient(500px 220px at 20% 0%, rgba(255,61,134,.25), transparent 60%),
    radial-gradient(500px 220px at 80% 10%, rgba(34,211,182,.20), transparent 55%),
    radial-gradient(500px 240px at 55% 85%, rgba(247,215,116,.18), transparent 55%);
  filter:blur(18px);
}
.heroCard__title{position:relative;font-weight:900;margin-bottom:12px}
.heroBadges{position:relative;display:flex;flex-wrap:wrap;gap:10px}
.badge{
  padding:10px 12px;border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18);
  font-weight:900;font-size:12px;
}
.heroCard__list{position:relative;margin-top:12px;color:rgba(234,240,255,.9);font-weight:700;font-size:13px;display:grid;gap:8px}
.heroCard__contact{position:relative;margin-top:12px;color:rgba(234,240,255,.85);font-size:12px}

.miniRow{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.mini{padding:14px;border-radius:18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12)}
.mini__t{font-weight:900;color:var(--jade)}
.mini__s{color:var(--muted);font-size:12px;margin-top:6px}

.fadeBottom{position:absolute;left:0;right:0;bottom:0;height:120px;background:linear-gradient(180deg, transparent, rgba(11,18,32,.95))}

.section{padding:70px 0}
.section--light{
  background:
    radial-gradient(900px 600px at 20% 10%, rgba(247,215,116,.10), transparent 55%),
    radial-gradient(900px 600px at 80% 40%, rgba(34,211,182,.08), transparent 55%),
    rgba(255,255,255,.02);
  border-top:1px solid rgba(255,255,255,.06);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.section--dark{background:rgba(0,0,0,.18)}
.section__head{margin-bottom:22px}
.section__head h2{margin:0;font-size:30px;letter-spacing:-.4px}
.section__head p{margin:10px 0 0;color:var(--muted);max-width:760px}

.grid{display:grid;gap:14px}
.grid.three{grid-template-columns:repeat(3,1fr)}
.grid.two{grid-template-columns:repeat(2,1fr)}
.grid.four{grid-template-columns:repeat(4,1fr)}

.card{
  padding:18px;border-radius:var(--r);
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 12px 40px rgba(0,0,0,.25);
}
.card h3{margin:10px 0 8px}
.card p{margin:0;color:var(--muted);font-size:14px;line-height:1.55}

.icon{width:46px;height:46px;border-radius:16px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12)}
.i1{background:linear-gradient(135deg, rgba(255,61,134,.35), rgba(247,215,116,.25))}
.i2{background:linear-gradient(135deg, rgba(34,211,182,.35), rgba(255,111,97,.2))}
.i3{background:linear-gradient(135deg, rgba(247,215,116,.32), rgba(34,211,182,.2))}
.i4{background:linear-gradient(135deg, rgba(255,111,97,.32), rgba(255,61,134,.2))}
.i5{background:linear-gradient(135deg, rgba(34,211,182,.32), rgba(247,215,116,.2))}
.i6{background:linear-gradient(135deg, rgba(255,61,134,.28), rgba(34,211,182,.2))}

.vcard{border-radius:var(--r);overflow:hidden;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);box-shadow:0 12px 40px rgba(0,0,0,.25)}
.thumbVideo{width:100%;height:220px;object-fit:cover;display:block}
.vmeta{padding:14px}
.vtitle{font-weight:900}
.vsub{color:var(--muted);font-size:12px;margin-top:4px}
.tip{margin-top:14px;color:rgba(234,240,255,.7);font-size:13px}

.masonry{columns:3;column-gap:14px}
.shot{break-inside:avoid;margin-bottom:14px;border-radius:var(--r);overflow:hidden;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.10)}
.shot img{width:100%;display:block;transform:scale(1.02)}

.steps .step{padding:18px;border-radius:var(--r);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12)}
.step__n{font-weight:900;color:var(--gold);font-size:14px}
.step h3{margin:10px 0 8px}
.step p{margin:0;color:var(--muted);font-size:13px;line-height:1.55}

.why .whyCard{padding:18px;border-radius:var(--r);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12)}
.whyCard h3{margin:0 0 8px;color:var(--gold)}
.whyCard p{margin:0;color:var(--muted);line-height:1.55}

.ctaBand{
  margin-top:18px;
  padding:18px;
  border-radius:var(--r);
  background:linear-gradient(135deg, rgba(255,61,134,.20), rgba(247,215,116,.12), rgba(34,211,182,.10));
  border:1px solid rgba(247,215,116,.25);
  display:flex;gap:14px;align-items:center;justify-content:space-between;flex-wrap:wrap;
}
.ctaBand__t{font-weight:900;font-size:16px}
.ctaBand__s{color:rgba(234,240,255,.82);font-size:13px}
.ctaBand__a{display:flex;gap:10px;flex-wrap:wrap}

.contactGrid{display:grid;grid-template-columns:1.2fr .8fr;gap:14px}
.contactBox,.contactInfo{border-radius:var(--r);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);padding:18px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
input,select,textarea{
  width:100%;padding:12px 12px;border-radius:16px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.18);
  color:#fff;font-family:inherit;outline:none;
}
textarea{margin-top:12px;resize:vertical}
input:focus,select:focus,textarea:focus{border-color: rgba(247,215,116,.5)}
.formMsg{margin-top:10px;color:rgba(234,240,255,.85);font-size:13px;min-height:18px}
.cLine{margin-top:10px;color:rgba(234,240,255,.88)}
.cLabel{display:inline-block;min-width:80px;color:rgba(234,240,255,.65)}
.contactInfo a{color:var(--jade);text-decoration:none}
.badgeRow{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}
.smallNote{margin-top:14px;color:var(--muted);font-size:13px}

.footer{
  padding:26px 0;border-top:1px solid rgba(255,255,255,.06);
  background:linear-gradient(180deg, rgba(11,18,32,.65), rgba(0,0,0,.25));
}
.footer__grid{display:grid;grid-template-columns:1.2fr 1fr .8fr;gap:14px;align-items:center}
.footer__links{display:flex;gap:14px;flex-wrap:wrap}
.footer__links a{text-decoration:none;color:rgba(234,240,255,.8)}
.footer__links a:hover{color:var(--gold)}
.footer__copy{color:rgba(234,240,255,.6);font-size:12px;text-align:right}

/* =========================
   3D Hover + Mobile-friendly
   ========================= */
.card3d{
  transform-style:preserve-3d;
  will-change:transform;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.card3d:hover{
  box-shadow: 0 25px 75px rgba(0,0,0,.48);
  border-color: rgba(247,215,116,.28);
}

/* Mobile: enable “tap” animation even without hover */
@media (hover: none) and (pointer: coarse){
  .card3d:active{
    transform: perspective(900px) rotateX(2deg) rotateY(-3deg) scale(0.98);
  }
}

/* Responsive */
@media (max-width: 1040px){
  .hero__grid{grid-template-columns:1fr}
  .trustRow{grid-template-columns:1fr}
  .grid.four{grid-template-columns:repeat(2,1fr)}
  .footer__grid{grid-template-columns:1fr;text-align:center}
  .footer__copy{text-align:center}
}
@media (max-width: 820px){
  .grid.three{grid-template-columns:repeat(2,1fr)}
  .contactGrid{grid-template-columns:1fr}
  .masonry{columns:2}
}
@media (max-width: 640px){
  .nav{display:none}
  .navbtn{display:block}
  .topbar__actions{display:none}
  .hero__title{font-size:32px}
  .grid.three,.grid.two{grid-template-columns:1fr}
  .grid.four{grid-template-columns:1fr}
  .masonry{columns:1}
  .frow{grid-template-columns:1fr}
}