/* ═══════════════════════════════════════════════════════════════════════════
   FX Entertainment — DJ theme
   ═══════════════════════════════════════════════════════════════════════════ */
:root {
  --fx-bg:        #07070d;
  --fx-bg-2:      #0d0d18;
  --fx-card:      #12121f;
  --fx-blue:      #00b2ff;
  --fx-blue-2:    #0080ff;
  --fx-magenta:   #b400ff;
  --fx-pink:      #ff2d92;
  --fx-text:      #e9ecf5;
  --fx-muted:     #9aa3b8;
  --fx-grad:      linear-gradient(100deg, var(--fx-blue), var(--fx-magenta));
  --fx-grad-soft: linear-gradient(100deg, rgba(0,178,255,.18), rgba(180,0,255,.18));
}

* { scroll-behavior: smooth; }
body {
  font-family: 'Poppins', sans-serif;
  background: var(--fx-bg);
  color: var(--fx-text);
  overflow-x: hidden;
}
h1,h2,h3,h4,h5,.fx-display { font-family: 'Outfit','Poppins',sans-serif; letter-spacing:-.01em; }
.fw-900 { font-weight: 900; }
.fx-grad-text {
  background: var(--fx-grad);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.section { padding: 96px 0; position: relative; }
.section-tight { padding: 64px 0; }
.eyebrow {
  text-transform: uppercase; letter-spacing: .25em; font-size: .78rem;
  font-weight: 700; color: var(--fx-blue); margin-bottom: .75rem;
}
.text-muted-2 { color: var(--fx-muted) !important; }

/* ── Buttons ──────────────────────────────────────────────────────────── */
.fx-btn {
  background: var(--fx-grad); color:#fff; border:0; font-weight:700;
  padding:.8rem 1.8rem; border-radius:50px; transition:.25s;
  box-shadow:0 8px 30px rgba(0,178,255,.35);
}
.fx-btn:hover { color:#fff; transform:translateY(-2px); box-shadow:0 12px 40px rgba(180,0,255,.5); filter:brightness(1.08); }
.fx-btn-sm { padding:.5rem 1.15rem; font-size:.9rem; box-shadow:0 6px 20px rgba(0,178,255,.3); }
.fx-btn-outline {
  background:transparent; color:#fff; border:2px solid rgba(255,255,255,.25);
  font-weight:700; padding:.7rem 1.7rem; border-radius:50px; transition:.25s;
}
.fx-btn-outline:hover { border-color:var(--fx-blue); color:var(--fx-blue); background:rgba(0,178,255,.08); }

/* ── Navbar ───────────────────────────────────────────────────────────── */
.fx-navbar { padding:1.1rem 0; transition:.3s; background:transparent; }
.fx-navbar.scrolled {
  background:rgba(7,7,13,.85); backdrop-filter:blur(14px);
  padding:.6rem 0; box-shadow:0 8px 30px rgba(0,0,0,.5);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.fx-logo-mark {
  width:38px;height:38px;display:grid;place-items:center;border-radius:50%;
  background:var(--fx-grad); color:#fff; font-size:1.1rem;
  box-shadow:0 0 18px rgba(0,178,255,.6); animation:spin 6s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }
.fx-logo-text { font-family:'Outfit',sans-serif; font-weight:800; font-size:1.15rem; color:#fff; }
.fx-logo-img { height:46px; width:auto; display:block; }
.fx-logo-img-footer { height:54px; }
@media (max-width:575.98px){ .fx-logo-img { height:38px; } }
.fx-navbar .nav-link { color:rgba(255,255,255,.8)!important; font-weight:500; padding:.5rem 1rem!important; position:relative; }
.fx-navbar .nav-link:hover, .fx-navbar .nav-link.active { color:#fff!important; }
.fx-navbar .nav-link.active::after {
  content:''; position:absolute; left:1rem; right:1rem; bottom:.25rem; height:2px;
  background:var(--fx-grad); border-radius:2px;
}
.navbar-toggler { border:0; color:#fff; font-size:1.6rem; box-shadow:none!important; }

/* ── Hero ─────────────────────────────────────────────────────────────── */
.fx-hero {
  position:relative; min-height:100vh; display:flex; align-items:center;
  text-align:center; overflow:hidden;
}
.fx-hero__bg {
  position:absolute; inset:0; background-size:cover; background-position:center;
  filter:brightness(.32) saturate(1.1); transform:scale(1.05);
}
.fx-hero__overlay {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 20% 20%, rgba(0,178,255,.25), transparent 50%),
    radial-gradient(ellipse at 80% 70%, rgba(180,0,255,.28), transparent 50%),
    linear-gradient(180deg, rgba(7,7,13,.55), rgba(7,7,13,.92));
}
.fx-hero__content { position:relative; z-index:2; }
.fx-hero h1 {
  font-weight:900; font-size:clamp(2.6rem,7vw,5.5rem); line-height:1.02; margin-bottom:1.2rem;
  text-shadow:0 0 40px rgba(0,178,255,.35);
}
.fx-hero .lead { font-size:clamp(1rem,2vw,1.3rem); color:#d7dcec; max-width:760px; margin:0 auto 2rem; }
.fx-badge-pill {
  display:inline-flex; align-items:center; gap:.5rem; padding:.45rem 1.1rem; border-radius:50px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.14);
  font-size:.85rem; font-weight:600; margin-bottom:1.5rem; backdrop-filter:blur(6px);
}
.fx-badge-pill .dot { width:8px;height:8px;border-radius:50%; background:var(--fx-blue); box-shadow:0 0 10px var(--fx-blue); animation:pulse 1.6s infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.35} }

/* equalizer accent */
.fx-eq { display:inline-flex; align-items:flex-end; gap:4px; height:34px; }
.fx-eq span { width:5px; background:var(--fx-grad); border-radius:3px; animation:eq 1s ease-in-out infinite; }
.fx-eq span:nth-child(2){animation-delay:.2s} .fx-eq span:nth-child(3){animation-delay:.4s}
.fx-eq span:nth-child(4){animation-delay:.1s} .fx-eq span:nth-child(5){animation-delay:.3s}
@keyframes eq { 0%,100%{height:10px} 50%{height:34px} }

/* ── Stats ────────────────────────────────────────────────────────────── */
.fx-stats { background:var(--fx-bg-2); border-top:1px solid rgba(255,255,255,.05); border-bottom:1px solid rgba(255,255,255,.05); }
.fx-stat__num { font-family:'Outfit',sans-serif; font-weight:900; font-size:clamp(2rem,5vw,3.2rem); }
.fx-stat__label { color:var(--fx-muted); font-size:.95rem; }

/* ── Cards ────────────────────────────────────────────────────────────── */
.fx-card {
  background:var(--fx-card); border:1px solid rgba(255,255,255,.07); border-radius:18px;
  overflow:hidden; height:100%; transition:.3s; position:relative;
}
.fx-card:hover { transform:translateY(-6px); border-color:rgba(0,178,255,.5); box-shadow:0 18px 50px rgba(0,178,255,.18); }
.fx-card__img { aspect-ratio:16/10; object-fit:cover; width:100%; }
.fx-card__body { padding:1.6rem; }
.fx-icon-chip {
  width:54px;height:54px;flex:0 0 auto;align-self:flex-start;
  border-radius:14px;display:grid;place-items:center;
  background:var(--fx-grad-soft); color:var(--fx-blue); font-size:1.5rem; margin-bottom:1rem;
  border:1px solid rgba(0,178,255,.25);
}
.fx-points { list-style:none; padding:0; margin:1rem 0 0; }
.fx-points li { display:flex; gap:.6rem; align-items:flex-start; color:var(--fx-muted); margin-bottom:.5rem; font-size:.95rem; }
.fx-points li i { color:var(--fx-blue); margin-top:.15rem; }

/* feature / why cards (no image) */
.fx-feature { background:var(--fx-card); border:1px solid rgba(255,255,255,.07); border-radius:16px; padding:1.8rem; height:100%; transition:.3s; }
.fx-feature:hover { transform:translateY(-4px); border-color:rgba(180,0,255,.4); box-shadow:0 14px 40px rgba(180,0,255,.15); }

/* ── Gallery ──────────────────────────────────────────────────────────── */
.fx-gal { position:relative; border-radius:16px; overflow:hidden; aspect-ratio:4/3; }
.fx-gal img { width:100%; height:100%; object-fit:cover; transition:.5s; }
.fx-gal:hover img { transform:scale(1.08); }
.fx-gal__cap {
  position:absolute; inset:auto 0 0 0; padding:1.4rem 1rem .9rem;
  background:linear-gradient(transparent, rgba(7,7,13,.9)); font-weight:600;
}

/* ── Testimonials ─────────────────────────────────────────────────────── */
.fx-quote { background:var(--fx-card); border:1px solid rgba(255,255,255,.07); border-radius:16px; padding:2rem; height:100%; }
.fx-quote .bi-quote { font-size:2.4rem; color:var(--fx-blue); opacity:.5; }
.fx-stars { color:#ffc107; }

/* ── Split / about ────────────────────────────────────────────────────── */
.fx-split-img { border-radius:18px; overflow:hidden; box-shadow:0 20px 60px rgba(0,0,0,.5); border:1px solid rgba(255,255,255,.08); }
.fx-split-img img { width:100%; height:100%; object-fit:cover; }

/* ── Page header (inner pages) ────────────────────────────────────────── */
.fx-page-head { padding:160px 0 70px; text-align:center; position:relative; background:var(--fx-bg-2); overflow:hidden; }
.fx-page-head::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 50% 0%, rgba(0,178,255,.18), transparent 60%);
}
.fx-page-head h1 { position:relative; font-weight:900; font-size:clamp(2.2rem,5vw,3.6rem); }
.fx-page-head p { position:relative; color:var(--fx-muted); max-width:640px; margin:.5rem auto 0; }

/* ── CTA strip ────────────────────────────────────────────────────────── */
.fx-cta-strip {
  padding:80px 0; text-align:center;
  background:linear-gradient(120deg, rgba(0,178,255,.12), rgba(180,0,255,.12)), var(--fx-bg-2);
  border-top:1px solid rgba(255,255,255,.06);
}

/* ── Contact / form ───────────────────────────────────────────────────── */
.fx-form .form-control {
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.14); color:#fff;
  padding:.85rem 1rem; border-radius:12px;
}
.fx-form .form-control::placeholder { color:rgba(255,255,255,.4); }
.fx-form .form-control:focus { background:rgba(255,255,255,.06); border-color:var(--fx-blue); box-shadow:0 0 0 .2rem rgba(0,178,255,.2); color:#fff; }
.fx-contact-card { background:var(--fx-card); border:1px solid rgba(255,255,255,.08); border-radius:18px; padding:2rem; }
.fx-contact-line { display:flex; gap:1rem; align-items:center; padding:1rem 0; border-bottom:1px solid rgba(255,255,255,.06); }
.fx-contact-line:last-child { border-bottom:0; }
.fx-contact-line .ic { width:46px;height:46px;border-radius:12px;display:grid;place-items:center; background:var(--fx-grad-soft); color:var(--fx-blue); font-size:1.25rem; flex:none; }
.fx-contact-line a { color:#fff; text-decoration:none; }
.fx-contact-line a:hover { color:var(--fx-blue); }
.fx-alert-ok { background:rgba(25,200,120,.12); border:1px solid rgba(25,200,120,.4); color:#7CFFB2; border-radius:12px; padding:1rem 1.2rem; }
.fx-alert-err { background:rgba(255,70,70,.12); border:1px solid rgba(255,70,70,.4); color:#ff9b9b; border-radius:12px; padding:1rem 1.2rem; }

/* ── Footer ───────────────────────────────────────────────────────────── */
.fx-footer { background:#05050a; padding:64px 0 30px; border-top:1px solid rgba(255,255,255,.06); }
.fx-foot-head { color:#fff; font-weight:700; margin-bottom:1rem; }
.fx-foot-links a, .fx-foot-contact a { color:var(--fx-muted); text-decoration:none; }
.fx-foot-links li, .fx-foot-contact li { margin-bottom:.6rem; }
.fx-foot-links a:hover, .fx-foot-contact a:hover { color:var(--fx-blue); }
.fx-foot-contact i { color:var(--fx-blue); margin-right:.5rem; }
.fx-social a {
  width:40px;height:40px;border-radius:10px;display:grid;place-items:center;
  background:rgba(255,255,255,.06); color:#fff; font-size:1.1rem; transition:.25s;
}
.fx-social a:hover { background:var(--fx-grad); transform:translateY(-3px); }

/* ── Scroll reveal ────────────────────────────────────────────────────── */
.reveal { opacity:0; transform:translateY(28px); transition:.7s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity:1; transform:none; }

/* divider glow line */
.fx-divider { height:1px; background:linear-gradient(90deg,transparent,rgba(0,178,255,.5),transparent); border:0; }
