/* NinoFollowers Premium Dark 2026 Theme - CLEANED VERSION */
/* Cleaned: removed old fake CSS flag, Petronas silhouette, abstract skyline, duplicate flag patches, and Made in Malaysia badge styles */

:root{
  --nf-bg:#050816;
  --nf-bg-2:#090f25;
  --nf-card:rgba(15,24,50,.78);
  --nf-card-2:rgba(22,34,69,.82);
  --nf-border:rgba(139,92,246,.25);
  --nf-border-2:rgba(255,255,255,.09);
  --nf-text:#f8fbff;
  --nf-muted:#9aa8c7;
  --nf-primary:#7c3aed;
  --nf-primary-2:#2563eb;
  --nf-orange:#ff7a1a;
  --nf-green:#22c55e;
  --nf-red:#ef4444;
  --nf-yellow:#f59e0b;
  --nf-shadow:0 24px 70px rgba(0,0,0,.35);
  --nf-radius:22px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}

body.nf-theme{
  font-family:'Poppins',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif!important;
  background:
    radial-gradient(circle at 10% 0%,rgba(124,58,237,.22),transparent 35%),
    radial-gradient(circle at 90% 10%,rgba(37,99,235,.19),transparent 35%),
    linear-gradient(135deg,#030612,#091024 55%,#050816);
  color:var(--nf-text);
  min-height:100vh;
  padding-bottom:0;
}

a{color:#a78bfa;transition:.25s ease}
a:hover{color:#fff;text-decoration:none}
img{max-width:100%}

.form-control{
  height:48px;
  border-radius:14px!important;
  border:1px solid var(--nf-border-2);
  background:rgba(4,10,28,.78);
  color:var(--nf-text);
  box-shadow:none;
}
.form-control:focus{
  border-color:rgba(124,58,237,.85);
  box-shadow:0 0 0 4px rgba(124,58,237,.14);
}
textarea.form-control{height:auto;min-height:140px}
label{color:#dce6ff;font-weight:600;font-size:13px}

.well,.panel,.media,.card{
  background:linear-gradient(180deg,rgba(17,28,59,.86),rgba(9,15,34,.88))!important;
  border:1px solid var(--nf-border)!important;
  border-radius:var(--nf-radius)!important;
  box-shadow:var(--nf-shadow);
  color:var(--nf-text);
}
.well{padding:22px;margin-bottom:18px}

.table{color:var(--nf-text);margin-bottom:0}
.table>thead>tr>th{
  border-bottom:1px solid var(--nf-border-2)!important;
  color:#cbd6f7;
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.04em;
}
.table>tbody>tr>td{
  border-top:1px solid rgba(255,255,255,.055)!important;
  color:#dbe6ff;
  vertical-align:middle;
}
.table-responsive{border:0}
.alert{border-radius:16px;border:0}

/* Public nav */
.nf-public-nav{
  position:absolute;
  left:0;right:0;top:0;
  z-index:10;
  background:transparent;
  border:0;
  padding:18px 0;
  transition:.25s ease;
}
.nf-public-nav.fixed,.navbar.bg-nav{
  position:fixed;
  background:rgba(5,8,22,.88)!important;
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--nf-border);
}
.nf-public-brand img{max-height:52px}
.nf-public-nav .navbar-nav>li>a{
  color:#e7edff!important;
  font-weight:600;
  border-radius:999px;
  padding:10px 16px;
}
.nf-public-nav .navbar-nav>li>a:hover,
.nf-public-nav .navbar-nav>.active>a{
  background:linear-gradient(135deg,var(--nf-primary),var(--nf-primary-2))!important;
  color:#fff!important;
}

/* Public hero / signin */
.nf-public-hero,#sec1{
  position:relative;
  overflow:hidden;
  padding:130px 0 90px;
  min-height:720px;
}
.nf-public-hero:before,#sec1:before{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 25% 20%,rgba(124,58,237,.32),transparent 28%),
    radial-gradient(circle at 75% 30%,rgba(37,99,235,.22),transparent 32%);
  pointer-events:none;
}
.nf-hero-premium{
  position:relative;
  overflow:hidden;
  padding-bottom:70px;
}
.nf-hero-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:36px;
  align-items:center;
  position:relative;
  z-index:2;
}
.nf-hero-left{position:relative;z-index:2}
.nf-eyebrow{
  color:#a78bfa;
  text-transform:uppercase;
  letter-spacing:.14em;
  font-weight:800;
  font-size:12px;
}
.nf-hero-title{
  font-size:56px;
  line-height:1.05;
  font-weight:800;
  margin:14px 0 16px;
}
.nf-gradient-text{
  background:linear-gradient(135deg,#fff,#a78bfa 45%,#38bdf8);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.nf-hero-copy{font-size:16px;color:#b9c5e3;max-width:580px}

/* Hero particles */
.nf-hero-effects{
  position:absolute;
  inset:0;
  overflow:hidden;
  pointer-events:none;
  z-index:1;
}
.nf-particle{
  position:absolute;
  border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.95) 0%, rgba(124,58,237,.55) 45%, rgba(37,99,235,0) 75%);
  box-shadow:
    0 0 14px rgba(255,255,255,.45),
    0 0 28px rgba(124,58,237,.25),
    0 0 40px rgba(37,99,235,.2);
  opacity:.55;
  filter:blur(.2px);
  animation:nfParticleFloat linear infinite;
}
.nf-particle.p1{width:10px;height:10px;top:10%;left:7%;animation-duration:12s}
.nf-particle.p2{width:16px;height:16px;top:20%;left:22%;animation-duration:15s;animation-delay:1s}
.nf-particle.p3{width:8px;height:8px;top:16%;right:18%;animation-duration:10s;animation-delay:2s}
.nf-particle.p4{width:14px;height:14px;top:40%;right:10%;animation-duration:14s;animation-delay:1.5s}
.nf-particle.p5{width:18px;height:18px;bottom:26%;left:12%;animation-duration:16s;animation-delay:3s}
.nf-particle.p6{width:9px;height:9px;bottom:16%;left:34%;animation-duration:11s;animation-delay:1s}
.nf-particle.p7{width:12px;height:12px;bottom:22%;right:22%;animation-duration:13s;animation-delay:2.5s}
.nf-particle.p8{width:20px;height:20px;top:28%;left:48%;animation-duration:18s;animation-delay:1.2s}

@keyframes nfParticleFloat{
  0%{transform:translate3d(0,0,0) scale(1);opacity:.25}
  25%{opacity:.6}
  50%{transform:translate3d(18px,-35px,0) scale(1.15);opacity:.85}
  75%{opacity:.45}
  100%{transform:translate3d(-12px,-80px,0) scale(.95);opacity:.15}
}

/* Real 3D Malaysia flag image wave */
.nf-flag-wave-wrap{
  position:relative;
  width:100%;
  max-width:560px;
  margin:28px 0 24px;
}
.nf-flag-wave-wrap .nf-flag-glow{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%, -50%);
  width:88%;
  height:82%;
  border-radius:28px;
  background:radial-gradient(circle, rgba(124,58,237,.34) 0%, rgba(37,99,235,.18) 42%, rgba(0,0,0,0) 76%);
  filter:blur(28px);
  z-index:1;
}
.nf-flag-wave-card{
  position:relative;
  z-index:2;
  width:100%;
  overflow:hidden;
  border-radius:24px;
  background:#0b1228;
  box-shadow:
    0 22px 55px rgba(0,0,0,.38),
    0 0 34px rgba(124,58,237,.16);
  transform-origin:left center;
  animation:nfFlagCardFloat 6s ease-in-out infinite;
}
.nf-flag-wave-card .nf-malaysia-flag-img{
  display:block;
  width:100%;
  height:auto;
  border-radius:24px;
  transform-origin:left center;
  position:relative;
  z-index:2;
  will-change:transform,filter;
  animation:nfFlagWaveRealistic 5.5s ease-in-out infinite;
  filter:saturate(1.05) contrast(1.03);
}
.nf-flag-wave-shadow{
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
  background:
    repeating-linear-gradient(
      90deg,
      rgba(0,0,0,0) 0px,
      rgba(0,0,0,0) 34px,
      rgba(0,0,0,.10) 34px,
      rgba(0,0,0,.10) 68px,
      rgba(255,255,255,.04) 68px,
      rgba(255,255,255,.04) 96px
    );
  opacity:.38;
  mix-blend-mode:multiply;
  animation:nfFlagRippleMove 4.2s ease-in-out infinite;
}
.nf-flag-wave-light{
  position:absolute;
  inset:0;
  z-index:4;
  pointer-events:none;
  background:linear-gradient(105deg,transparent 0%,rgba(255,255,255,.20) 28%,rgba(255,255,255,.08) 45%,transparent 64%);
  transform:translateX(-120%);
  animation:nfFlagShineSweep 4.8s ease-in-out infinite;
}
@keyframes nfFlagCardFloat{
  0%,100%{transform:translateY(0) rotate(-0.15deg)}
  50%{transform:translateY(-6px) rotate(0.15deg)}
}
@keyframes nfFlagWaveRealistic{
  0%,100%{transform:perspective(1400px) rotateY(-12deg) rotateX(2deg) skewY(-1deg) scale(1)}
  20%{transform:perspective(1400px) rotateY(-9deg) rotateX(3deg) skewY(-.3deg) scale(1.004)}
  40%{transform:perspective(1400px) rotateY(-5deg) rotateX(4deg) skewY(.8deg) scale(1.009)}
  60%{transform:perspective(1400px) rotateY(-7deg) rotateX(3.4deg) skewY(.2deg) scale(1.005)}
  80%{transform:perspective(1400px) rotateY(-10deg) rotateX(2.8deg) skewY(-.8deg) scale(1.002)}
}
@keyframes nfFlagRippleMove{
  0%,100%{transform:translateX(0);opacity:.24}
  25%{transform:translateX(6px);opacity:.34}
  50%{transform:translateX(12px);opacity:.44}
  75%{transform:translateX(6px);opacity:.32}
}
@keyframes nfFlagShineSweep{
  0%{transform:translateX(-120%);opacity:0}
  18%{opacity:.70}
  50%{opacity:.30}
  100%{transform:translateX(120%);opacity:0}
}

/* Trust cards */
.nf-trust-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-top:18px;
}
.nf-trust-item,.nf-browser-badge{
  padding:14px;
  border-radius:18px;
  background:rgba(15,24,50,.7);
  border:1px solid var(--nf-border);
}
.nf-trust-item strong{display:block;font-size:18px}
.nf-trust-item span{color:var(--nf-muted);font-size:12px}

/* Login card */
.nf-auth-card{
  position:relative;
  overflow:hidden;
  padding:28px;
  border-radius:28px;
  background:linear-gradient(180deg,rgba(17,28,59,.90),rgba(8,13,31,.94))!important;
  border:1px solid rgba(167,139,250,.26)!important;
  box-shadow:
    0 30px 90px rgba(0,0,0,.42),
    0 0 0 1px rgba(255,255,255,.04),
    0 0 60px rgba(124,58,237,.10);
}
.nf-auth-card::before{
  content:"";
  position:absolute;
  inset:-2px;
  background:
    radial-gradient(circle at 12% 0%,rgba(124,58,237,.22),transparent 34%),
    radial-gradient(circle at 100% 100%,rgba(37,99,235,.18),transparent 36%);
  opacity:.9;
  pointer-events:none;
  z-index:0;
}
.nf-auth-card::after{
  content:"";
  position:absolute;
  top:-120px;
  right:-120px;
  width:260px;
  height:260px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(96,165,250,.20),transparent 65%);
  filter:blur(4px);
  animation:nfCardGlow 6s ease-in-out infinite;
  pointer-events:none;
  z-index:0;
}
.nf-auth-card>*{position:relative;z-index:1}
.nf-auth-card h2{font-weight:800;margin-top:0}
.nf-auth-card .form-control{
  height:54px;
  margin-bottom:14px;
  border-radius:17px!important;
  background:rgba(226,232,240,.95);
  color:#0f172a;
  border:1px solid rgba(255,255,255,.12);
  font-weight:600;
}
.nf-auth-card .form-control::placeholder{color:#64748b}
.nf-auth-card .form-control:focus{
  background:#fff;
  color:#0f172a;
  border-color:rgba(124,58,237,.65);
  box-shadow:
    0 0 0 4px rgba(124,58,237,.16),
    0 12px 28px rgba(0,0,0,.18);
}
@keyframes nfCardGlow{
  0%,100%{transform:translate(0,0) scale(1);opacity:.65}
  50%{transform:translate(-18px,20px) scale(1.08);opacity:1}
}

/* Buttons */
.nf-btn,.dash-btn,.btn.btn-primary,.home-form .btn.btn-primary{
  position:relative;
  overflow:hidden;
  isolation:isolate;
  border:1px solid rgba(255,255,255,.10)!important;
  border-radius:15px!important;
  color:#fff!important;
  background:linear-gradient(135deg,#7c3aed 0%,#2563eb 52%,#06b6d4 100%)!important;
  box-shadow:
    0 14px 30px rgba(124,58,237,.28),
    inset 0 1px 0 rgba(255,255,255,.18);
  font-weight:700;
  padding:13px 22px;
  transition:.25s ease;
  transform:translateZ(0);
}
.nf-btn::before,.dash-btn::before,.btn.btn-primary::before,.home-form .btn.btn-primary::before{
  content:"";
  position:absolute;
  inset:-2px;
  z-index:-1;
  background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.35) 45%,transparent 75%);
  transform:translateX(-130%);
  transition:transform .75s ease;
}
.nf-btn::after,.dash-btn::after,.btn.btn-primary::after,.home-form .btn.btn-primary::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  background:radial-gradient(circle at 50% 120%,rgba(255,255,255,.22),transparent 45%);
  opacity:0;
  transition:opacity .35s ease;
}
.nf-btn:hover,.dash-btn:hover,.btn.btn-primary:hover,.home-form .btn.btn-primary:hover{
  transform:translateY(-3px) scale(1.01);
  box-shadow:
    0 22px 46px rgba(124,58,237,.42),
    0 0 24px rgba(37,99,235,.26),
    inset 0 1px 0 rgba(255,255,255,.22);
}
.nf-btn:hover::before,.dash-btn:hover::before,.btn.btn-primary:hover::before,.home-form .btn.btn-primary:hover::before{transform:translateX(130%)}
.nf-btn:hover::after,.dash-btn:hover::after,.btn.btn-primary:hover::after,.home-form .btn.btn-primary:hover::after{opacity:1}
.nf-btn:active,.dash-btn:active,.btn.btn-primary:active{transform:translateY(0) scale(.99)}
.nf-btn-orange{
  background:linear-gradient(135deg,#ffb142 0%,#ff7a1a 50%,#ff4d00 100%)!important;
  box-shadow:
    0 16px 34px rgba(255,122,26,.28),
    inset 0 1px 0 rgba(255,255,255,.24);
}
.nf-btn-orange:hover{
  box-shadow:
    0 24px 50px rgba(255,122,26,.38),
    0 0 24px rgba(255,122,26,.28),
    inset 0 1px 0 rgba(255,255,255,.28);
}

/* Auth dashboard layout */
.nf-app{display:flex;min-height:100vh}
.nf-sidebar{
  width:270px;
  position:fixed;top:0;bottom:0;left:0;
  background:linear-gradient(180deg,rgba(12,18,40,.97),rgba(4,8,22,.97));
  border-right:1px solid var(--nf-border);
  z-index:100;
  transition:.25s ease;
}
#wrapper:not(.toggled) .nf-sidebar{transform:translateX(-100%)}
.nf-main{
  width:100%;
  margin-left:270px;
  min-height:100vh;
  transition:.25s ease;
}
#wrapper:not(.toggled) .nf-main{margin-left:0}
.nf-sidebar-inner{height:100%;padding:18px;overflow:auto}
.nf-brand{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.nf-brand img{max-height:58px}
.nf-close-sidebar{display:none}
.nf-user-card{
  display:flex;gap:12px;align-items:center;
  padding:14px;border-radius:18px;
  background:rgba(124,58,237,.12);
  border:1px solid var(--nf-border);
  margin-bottom:14px;
}
.nf-user-avatar{
  width:42px;height:42px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--nf-primary),var(--nf-primary-2));
}
.nf-user-card span{display:block;color:var(--nf-muted);font-size:12px}
.nf-balance-mobile{
  display:none;
  justify-content:space-between;align-items:center;
  margin-bottom:14px;
  padding:12px 14px;
  border-radius:16px;
  background:rgba(34,197,94,.12);
  border:1px solid rgba(34,197,94,.25);
}
.nf-menu{list-style:none;padding:0;margin:0}
.nf-menu li a{
  display:flex;align-items:center;gap:12px;
  color:#cbd6f7!important;
  padding:12px 14px;
  border-radius:15px;
  font-weight:600;
  margin:4px 0;
}
.nf-menu li.active a,.nf-menu li a:hover{
  color:#fff!important;
  background:linear-gradient(135deg,rgba(124,58,237,.95),rgba(37,99,235,.82));
  box-shadow:0 10px 24px rgba(124,58,237,.25);
}
.nf-affiliate-card{
  margin-top:18px;padding:16px;border-radius:18px;
  background:rgba(255,122,26,.1);
  border:1px solid rgba(255,122,26,.25);
}
.nf-affiliate-card i{font-size:24px;color:var(--nf-orange)}
.nf-affiliate-card p{color:var(--nf-muted);font-size:12px}
.nf-topbar{
  position:sticky;top:0;z-index:80;
  min-height:80px;
  margin:0;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 24px;
  background:rgba(5,8,22,.82)!important;
  backdrop-filter:blur(18px);
  border:0;border-bottom:1px solid var(--nf-border);
}
.nf-topbar-left{display:flex;align-items:center;gap:14px}
.nf-topbar h1{margin:0;color:#fff;font-size:22px;font-weight:800}
.nf-breadcrumb{color:var(--nf-muted);font-size:12px}
.nf-topbar-right{display:flex;align-items:center;gap:10px}
.nf-icon-btn{
  width:44px;height:44px;border-radius:15px;border:1px solid var(--nf-border);
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(15,24,50,.72);color:#fff;
  position:relative;
}
.nf-top-pill{
  height:44px;border-radius:15px;border:1px solid var(--nf-border);
  display:inline-flex;align-items:center;gap:8px;padding:0 14px;
  background:rgba(15,24,50,.72);color:#fff!important;font-weight:700;
}
.nf-dot{position:absolute;right:10px;top:9px;width:8px;height:8px;background:#ef4444;border-radius:50%}
.nf-user-dropdown>a{color:#fff!important;background:rgba(15,24,50,.72);border:1px solid var(--nf-border);border-radius:15px;padding:12px 14px;display:block}
.nf-content{padding:24px}

/* Dashboard cards */
.stat{margin-bottom:18px}
.stat-wrap .media{
  min-height:112px;
  padding:18px;
  display:flex;
  align-items:center;
  gap:14px;
}
.stat-wrap .media-left{float:none!important}
.media-object{
  width:54px;height:54px;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(124,58,237,.16);
  color:#fff;font-size:22px;
}
.obj1{background:linear-gradient(135deg,#7c3aed,#2563eb)}
.obj2{background:linear-gradient(135deg,#2563eb,#06b6d4)}
.obj3{background:linear-gradient(135deg,#10b981,#059669)}
.obj4{background:linear-gradient(135deg,#ff7a1a,#ef4444)}
.media-body{padding:0!important}
.media-desc{font-size:22px!important;font-weight:800;color:#fff!important;margin:0}
.media-heading{font-size:13px!important;color:var(--nf-muted)!important;margin:4px 0 0!important}
.dash-title h2,.order-title h2{
  font-size:22px;font-weight:800;margin:0 0 16px;color:#fff;
}

/* Tabs / pills / badges */
.nav-tabs,.nav-pills{border:0}
.nav-tabs>li>a,.nav-pills>li>a{
  color:#cbd6f7!important;
  border:1px solid var(--nf-border-2)!important;
  border-radius:14px!important;
  background:rgba(4,10,28,.45)!important;
  margin-right:8px;
}
.nav-tabs>li.active>a,.nav-pills>li.active>a,
.nav-tabs>li>a:hover,.nav-pills>li>a:hover{
  color:#fff!important;
  background:linear-gradient(135deg,var(--nf-primary),var(--nf-primary-2))!important;
  border-color:transparent!important;
}
.panel-body.border-rounded{
  border-radius:16px;
  border:1px solid var(--nf-border-2);
  background:rgba(4,10,28,.55);
  color:#dbe6ff;
}
.badge,.statusbtn{
  border-radius:999px!important;
  padding:7px 11px!important;
  font-weight:700;
}
.status-pending,.Pending{background:#f59e0b!important;color:#111827!important}
.status-inprogress,.status-processing,.Processing{background:#2563eb!important;color:#fff!important}
.status-partial,.Partial{background:#8b5cf6!important;color:#fff!important}
.status-canceled,.Canceled{background:#ef4444!important;color:#fff!important}
.status-complete,.Completed,.Answered{background:#22c55e!important;color:#052e16!important}
.Open{background:#22c55e!important;color:#052e16!important}
.Closed{background:#475569!important;color:#fff!important}
.rateper{background:rgba(34,197,94,.16);color:#86efac}
.minorder,.mxnorder{background:rgba(124,58,237,.16);color:#ddd6fe}
.easypaisa{
  padding:16px;border-radius:18px;
  background:rgba(255,122,26,.1);
  border:1px solid rgba(255,122,26,.25);
  margin:14px 0;
}
.easypaisa p{margin:0;color:#fed7aa}

/* Modal */
.modal-content{
  background:linear-gradient(180deg,#101b3b,#080d1f)!important;
  color:#fff;
  border:1px solid var(--nf-border);
  border-radius:22px;
  box-shadow:var(--nf-shadow);
}
.modal-header,.modal-footer{border-color:var(--nf-border-2)}
.close{color:#fff;opacity:.85}

/* Services */
#serv-page-search{position:relative;margin:0}
#serv-page-search .search-icon{position:absolute;right:16px;top:13px;color:var(--nf-muted)}
.cat-title td{
  background:linear-gradient(135deg,rgba(124,58,237,.24),rgba(37,99,235,.15))!important;
  color:#fff!important;
  font-weight:800;
}
.id-td button{
  border:1px solid var(--nf-border);
  background:rgba(124,58,237,.16);
  border-radius:999px;
  padding:5px 10px;
  font-size:11px;
  color:#fff;
}

/* Tickets */
.ticket-message-block{margin:16px 0}
.ticket-message{
  max-width:80%;
  padding:14px 16px;
  border-radius:18px;
  background:rgba(15,24,50,.82);
  border:1px solid var(--nf-border-2);
}
.ticket-message-right .ticket-message{
  margin-left:auto;
  background:linear-gradient(135deg,rgba(124,58,237,.72),rgba(37,99,235,.72));
}
.ticket-message-left .ticket-message{margin-right:auto}
.tickat-page .avatar{
  width:42px;height:42px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(124,58,237,.22);
  margin-bottom:8px;
}
.titcket-title{
  font-size:24px;
  font-weight:800;
  margin-bottom:18px;
}

/* Below hero sections */
#sec2{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 20% 0%,rgba(124,58,237,.10),transparent 34%),
    linear-gradient(180deg,rgba(5,8,22,0),rgba(5,8,22,.56));
}
#sec2 .nf-browser-badge{
  position:relative;
  min-height:58px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:20px;
  background:linear-gradient(180deg,rgba(17,28,59,.88),rgba(8,13,31,.92));
  border:1px solid rgba(167,139,250,.20);
  box-shadow:0 18px 44px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.06);
  font-weight:700;
  color:#dbe6ff;
}
#sec2 .nf-browser-badge::before{
  content:"";
  width:8px;
  height:8px;
  border-radius:50%;
  margin-right:9px;
  background:linear-gradient(135deg,#7c3aed,#38bdf8);
  box-shadow:0 0 16px rgba(56,189,248,.6);
}
#work{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 50% 0%,rgba(124,58,237,.12),transparent 34%),
    linear-gradient(180deg,rgba(5,8,22,.2),rgba(5,8,22,.86));
}
#work::before{
  content:"";
  position:absolute;
  left:50%;
  top:0;
  width:760px;
  height:1px;
  transform:translateX(-50%);
  background:linear-gradient(90deg,transparent,rgba(167,139,250,.45),transparent);
}
#work .well{
  position:relative;
  min-height:220px;
  overflow:hidden;
  transition:transform .3s ease,border-color .3s ease,box-shadow .3s ease;
}
#work .well::before{
  content:"";
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 0%,rgba(124,58,237,.16),transparent 52%);
  opacity:0;
  transition:opacity .3s ease;
  pointer-events:none;
}
#work .well:hover{
  transform:translateY(-8px);
  border-color:rgba(167,139,250,.42)!important;
  box-shadow:0 30px 80px rgba(0,0,0,.34),0 0 42px rgba(124,58,237,.12);
}
#work .well:hover::before{opacity:1}
#work .media-object{
  position:relative;
  box-shadow:0 0 28px rgba(124,58,237,.18),inset 0 1px 0 rgba(255,255,255,.15);
}

/* Footer */
.nf-footer{
  padding:36px 0 22px;
  background:rgba(3,6,18,.92);
  border-top:1px solid var(--nf-border);
}
.nf-footer img{max-height:52px}
.nf-footer h6{font-weight:800;color:#fff}
.nf-footer p,.nf-footer a{display:block;color:var(--nf-muted);margin-bottom:8px}
.nf-footer-bottom{
  margin-top:22px;
  padding-top:18px;
  border-top:1px solid var(--nf-border-2);
  display:flex;
  justify-content:space-between;
  color:var(--nf-muted);
}

/* Mobile */
@media(max-width:991px){
  .nf-public-nav{
    position:fixed;
    padding:10px 0;
    background:rgba(5,8,22,.76)!important;
    backdrop-filter:blur(18px);
    border-bottom:1px solid rgba(167,139,250,.18);
  }
  .nf-public-nav .container{width:100%;padding-left:16px;padding-right:16px}
  .nf-public-brand img{max-height:44px}
  .nf-public-nav .navbar-toggle{
    border:1px solid rgba(167,139,250,.32);
    border-radius:14px;
    margin-top:5px;
    margin-right:0;
    background:rgba(15,24,50,.68);
  }
  .nf-public-nav .navbar-toggle .icon-bar{background:#fff}
  .nf-public-nav .navbar-collapse{
    border:0;
    box-shadow:none;
    margin-top:12px;
    padding:10px;
    background:rgba(8,13,31,.96);
    border:1px solid rgba(167,139,250,.20);
    border-radius:20px;
  }
  .nf-public-nav .navbar-nav{margin:0}
  .nf-public-nav .navbar-nav>li{margin:4px 0}
  .nf-public-nav .navbar-nav>li>a{
    padding:13px 16px;
    border-radius:14px;
    text-align:left;
    background:rgba(255,255,255,.03);
  }
  .nf-public-nav .navbar-nav>li.active>a,
  .nf-public-nav .navbar-nav>li>a:hover{
    background:linear-gradient(135deg,rgba(124,58,237,.95),rgba(37,99,235,.82))!important;
  }

  .nf-sidebar{transform:translateX(-100%)}
  #wrapper.toggled .nf-sidebar{transform:translateX(0)}
  .nf-main{margin-left:0}
  .nf-close-sidebar{display:flex}
  .nf-topbar{padding:12px 14px}
  .nf-topbar h1{font-size:18px}
  .nf-topbar-right .nf-user-dropdown,
  .nf-topbar-right .nf-icon-btn:nth-child(n+3){display:none}
  .nf-content{padding:14px}
  .stat-wrap{margin-bottom:12px}
  .nf-hero-grid{grid-template-columns:1fr}
  .nf-hero-title{font-size:42px}
  .nf-trust-row{grid-template-columns:repeat(2,1fr)}
  .nf-flag-wave-wrap{margin-left:auto;margin-right:auto;max-width:460px}
  .table-responsive{border:0;overflow-x:auto}
}

@media(max-width:600px){
  .nf-hero-title{font-size:34px}
  .nf-public-hero,#sec1{padding-top:105px}
  .nf-auth-card{padding:20px}
  .nf-trust-row{grid-template-columns:1fr 1fr}
  .nf-flag-wave-wrap{max-width:320px;margin:22px auto 18px}
  .nf-flag-wave-card,
  .nf-flag-wave-card .nf-malaysia-flag-img{border-radius:18px}
  .nf-footer-bottom{display:block}
  .nav-tabs>li,.nav-pills>li{float:none;display:inline-block;margin-bottom:8px}
  #work .well{min-height:auto}
}

/* Removed unused legacy classes:
   .nf-malaysia-flag, .nf-petronas-scene, .nf-tower, .nf-bridge,
   .nf-ground-glow, .nf-malaysia-skyline, .nf-building,
   .nf-skyline-glow, .nf-malaysia-badge, .nf-badge-dot
*/
/* =========================================
   MALAYSIA FLAG - NO BLACK BACKGROUND
   No upload needed, uses Wikimedia SVG
   ========================================= */

.nf-malaysia-skyline,
.nf-petronas-scene,
.nf-building,
.nf-skyline-glow,
.nf-tower,
.nf-bridge,
.nf-ground-glow,
.nf-malaysia-badge,
.nf-badge-dot{
  display:none !important;
}

.nf-flag-wave-wrap{
  position:relative;
  width:100%;
  max-width:560px;
  margin:28px 0 24px;
  background:transparent !important;
}

.nf-flag-wave-wrap .nf-flag-glow{
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%, -50%);
  width:88%;
  height:78%;
  border-radius:50%;
  background:radial-gradient(circle, rgba(124,58,237,.30) 0%, rgba(37,99,235,.16) 42%, rgba(0,0,0,0) 76%);
  filter:blur(30px);
  z-index:1;
}

.nf-flag-wave-card{
  position:relative;
  z-index:2;
  width:100%;
  overflow:visible !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  transform-origin:left center;
  animation:nfFlagCardFloat 6s ease-in-out infinite;
}

.nf-flag-wave-card .nf-malaysia-flag-img{
  display:block;
  width:100%;
  height:auto;
  border-radius:0 !important;
  background:transparent !important;
  position:relative;
  z-index:2;
  transform-origin:left center;
  will-change:transform, filter;
  animation:nfFlagWaveClean 5.6s ease-in-out infinite;
  filter:
    drop-shadow(0 22px 32px rgba(0,0,0,.32))
    drop-shadow(0 0 22px rgba(124,58,237,.18))
    saturate(1.08)
    contrast(1.04);
}

/* soft cloth shadow illusion */
.nf-flag-wave-shadow{
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
  border-radius:0 !important;
  background:
    repeating-linear-gradient(
      90deg,
      rgba(0,0,0,0) 0px,
      rgba(0,0,0,0) 38px,
      rgba(0,0,0,.10) 38px,
      rgba(0,0,0,.10) 72px,
      rgba(255,255,255,.05) 72px,
      rgba(255,255,255,.05) 104px
    );
  opacity:.22;
  mix-blend-mode:multiply;
  animation:nfFlagRippleMove 4.4s ease-in-out infinite;
}

/* moving highlight */
.nf-flag-wave-light{
  position:absolute;
  inset:0;
  z-index:4;
  pointer-events:none;
  border-radius:0 !important;
  background:linear-gradient(
    105deg,
    transparent 0%,
    rgba(255,255,255,.18) 28%,
    rgba(255,255,255,.06) 45%,
    transparent 64%
  );
  transform:translateX(-120%);
  animation:nfFlagShineSweep 4.8s ease-in-out infinite;
}

@keyframes nfFlagCardFloat{
  0%,100%{
    transform:translateY(0) rotate(-0.15deg);
  }
  50%{
    transform:translateY(-6px) rotate(0.15deg);
  }
}

@keyframes nfFlagWaveClean{
  0%,100%{
    transform:perspective(1400px) rotateY(-10deg) rotateX(2deg) skewY(-1deg) scale(1);
  }
  20%{
    transform:perspective(1400px) rotateY(-7deg) rotateX(3deg) skewY(-.3deg) scale(1.004);
  }
  40%{
    transform:perspective(1400px) rotateY(-4deg) rotateX(4deg) skewY(.8deg) scale(1.01);
  }
  60%{
    transform:perspective(1400px) rotateY(-6deg) rotateX(3.4deg) skewY(.2deg) scale(1.005);
  }
  80%{
    transform:perspective(1400px) rotateY(-8deg) rotateX(2.8deg) skewY(-.8deg) scale(1.002);
  }
}

@keyframes nfFlagRippleMove{
  0%,100%{
    transform:translateX(0);
    opacity:.16;
  }
  25%{
    transform:translateX(6px);
    opacity:.24;
  }
  50%{
    transform:translateX(12px);
    opacity:.30;
  }
  75%{
    transform:translateX(6px);
    opacity:.22;
  }
}

@keyframes nfFlagShineSweep{
  0%{
    transform:translateX(-120%);
    opacity:0;
  }
  18%{
    opacity:.60;
  }
  50%{
    opacity:.25;
  }
  100%{
    transform:translateX(120%);
    opacity:0;
  }
}

@media (max-width:991px){
  .nf-flag-wave-wrap{
    max-width:460px;
    margin-left:auto;
    margin-right:auto;
  }
}

@media (max-width:600px){
  .nf-flag-wave-wrap{
    max-width:320px;
    margin:22px auto 18px;
  }

  .nf-flag-wave-shadow,
  .nf-flag-wave-light{
    display:none;
  }
}
/* Fix charge input visibility */
#charge,
input#charge.form-control,
.neworder #charge{
  background:#ffffff !important;
  color:#0f172a !important;
  border:1px solid rgba(124,58,237,.35) !important;
  font-weight:800 !important;
}

#charge[readonly],
input#charge[readonly]{
  background:#ffffff !important;
  color:#0f172a !important;
  opacity:1 !important;
}

/* Optional: make all readonly inputs readable */
input.form-control[readonly]{
  background:#ffffff !important;
  color:#0f172a !important;
  opacity:1 !important;
}
/* =========================================
   LOGO SIZE FIX - NinoFollowers
   Bigger logo for header/sidebar/footer
   ========================================= */

/* Public top navbar logo */
.nf-public-brand{
  display:flex !important;
  align-items:center !important;
  padding:0 !important;
  height:auto !important;
}

.nf-public-brand img{
  width:200px !important;
  height:80px !important;
  max-width:200px !important;
  max-height:80px !important;
  object-fit:contain !important;
  display:block !important;
}

/* Make navbar height fit bigger logo */
.nf-public-nav{
  min-height:90px !important;
  padding:8px 0 !important;
}

.nf-public-nav .navbar-header{
  display:flex !important;
  align-items:center !important;
  min-height:80px !important;
}

/* Sidebar logo after login */
.nf-brand img{
  width:200px !important;
  height:80px !important;
  max-width:200px !important;
  max-height:80px !important;
  object-fit:contain !important;
  display:block !important;
}

/* Footer logo */
.nf-footer-brand img,
.nf-footer img{
  width:200px !important;
  height:80px !important;
  max-width:200px !important;
  max-height:80px !important;
  object-fit:contain !important;
}

/* Mobile size */
@media(max-width:991px){
  .nf-public-brand img{
    width:150px !important;
    height:60px !important;
    max-width:150px !important;
    max-height:60px !important;
  }

  .nf-public-nav{
    min-height:72px !important;
    padding:6px 0 !important;
  }

  .nf-public-nav .navbar-header{
    min-height:60px !important;
  }

  .nf-brand img{
    width:160px !important;
    height:64px !important;
    max-width:160px !important;
    max-height:64px !important;
  }
}

@media(max-width:600px){
  .nf-public-brand img{
    width:125px !important;
    height:50px !important;
    max-width:125px !important;
    max-height:50px !important;
  }

  .nf-brand img{
    width:140px !important;
    height:56px !important;
    max-width:140px !important;
    max-height:56px !important;
  }
}
/* Force service icons visible - FontAwesome version */
.svc-icon{
  width:28px !important;
  height:28px !important;
  min-width:28px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  border-radius:9px !important;
  margin-right:10px !important;
  vertical-align:middle !important;
  box-shadow:0 8px 18px rgba(0,0,0,.22) !important;
  border:1px solid rgba(255,255,255,.10) !important;
}

.svc-icon i{
  display:block !important;
  font-size:15px !important;
  color:#fff !important;
  line-height:1 !important;
}

.svc-name-text{
  display:inline-block !important;
  vertical-align:middle !important;
  color:#eaf1ff !important;
  font-weight:600 !important;
}

.service-category-name .svc-name-text{
  color:#fff !important;
  font-weight:800 !important;
}

.svc-instagram{background:linear-gradient(135deg,#833ab4,#fd1d1d,#fcb045) !important;}
.svc-tiktok{background:linear-gradient(135deg,#111827,#00f2ea,#ff0050) !important;}
.svc-telegram{background:linear-gradient(135deg,#229ED9,#38bdf8) !important;}
.svc-youtube{background:linear-gradient(135deg,#ff0000,#ff4d4d) !important;}
.svc-facebook{background:linear-gradient(135deg,#1877f2,#60a5fa) !important;}
.svc-x{background:linear-gradient(135deg,#111827,#374151) !important;}
.svc-spotify{background:linear-gradient(135deg,#1db954,#15803d) !important;}
.svc-discord{background:linear-gradient(135deg,#5865F2,#8b5cf6) !important;}
.svc-whatsapp{background:linear-gradient(135deg,#25D366,#128C7E) !important;}
.svc-linkedin{background:linear-gradient(135deg,#0A66C2,#38bdf8) !important;}
.svc-threads{background:linear-gradient(135deg,#111827,#4b5563) !important;}
.svc-snapchat{background:linear-gradient(135deg,#facc15,#eab308) !important;}
.svc-pinterest{background:linear-gradient(135deg,#E60023,#ff6b6b) !important;}
.svc-twitch{background:linear-gradient(135deg,#9146FF,#7c3aed) !important;}
.svc-soundcloud{background:linear-gradient(135deg,#ff5500,#ff8800) !important;}
.svc-website,
.svc-default{background:linear-gradient(135deg,#7c3aed,#2563eb,#06b6d4) !important;}
/* =========================================
   NEW ORDER ANIMATION PATCH
   Lightweight / Responsive
   ========================================= */

/* Page fade in */
.neworder{
  animation:nfPageFadeUp .55s ease both;
}

@keyframes nfPageFadeUp{
  from{
    opacity:0;
    transform:translateY(14px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

/* Stats card hover animation */
.neworder .stat-wrap .media{
  position:relative;
  overflow:hidden;
  transition:
    transform .28s ease,
    box-shadow .28s ease,
    border-color .28s ease;
}

.neworder .stat-wrap .media::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(
    110deg,
    transparent 0%,
    rgba(255,255,255,.10) 42%,
    transparent 70%
  );
  transform:translateX(-130%);
  transition:transform .75s ease;
  pointer-events:none;
}

.neworder .stat-wrap .media:hover{
  transform:translateY(-7px);
  border-color:rgba(167,139,250,.42) !important;
  box-shadow:
    0 28px 70px rgba(0,0,0,.34),
    0 0 35px rgba(124,58,237,.14);
}

.neworder .stat-wrap .media:hover::before{
  transform:translateX(130%);
}

/* Icon floating */
.neworder .media-object{
  animation:nfIconFloat 4.5s ease-in-out infinite;
}

.neworder .stat-wrap:nth-child(2) .media-object{
  animation-delay:.4s;
}

.neworder .stat-wrap:nth-child(3) .media-object{
  animation-delay:.8s;
}

.neworder .stat-wrap:nth-child(4) .media-object{
  animation-delay:1.2s;
}

@keyframes nfIconFloat{
  0%,100%{
    transform:translateY(0) scale(1);
  }
  50%{
    transform:translateY(-4px) scale(1.04);
  }
}

/* Main order card glow */
.neworder .well{
  position:relative;
  overflow:hidden;
}

.neworder .well::after{
  content:"";
  position:absolute;
  width:180px;
  height:180px;
  right:-80px;
  top:-80px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(124,58,237,.18), transparent 65%);
  filter:blur(2px);
  animation:nfCardGlowMove 7s ease-in-out infinite;
  pointer-events:none;
}

@keyframes nfCardGlowMove{
  0%,100%{
    transform:translate(0,0) scale(1);
    opacity:.55;
  }
  50%{
    transform:translate(-30px,35px) scale(1.18);
    opacity:.95;
  }
}

/* Tabs smoother */
.neworder .dash-tabs > li > a{
  transition:
    transform .22s ease,
    box-shadow .22s ease,
    background .22s ease;
}

.neworder .dash-tabs > li > a:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 28px rgba(124,58,237,.22);
}

/* Category/service badge pulse */
.nf-order-badge{
  position:relative;
  overflow:hidden;
  animation:nfBadgePulse 2.7s ease-in-out infinite;
}

.nf-order-badge::after{
  content:"";
  position:absolute;
  inset:-2px;
  background:linear-gradient(
    120deg,
    transparent 0%,
    rgba(255,255,255,.28) 45%,
    transparent 70%
  );
  transform:translateX(-130%);
  animation:nfBadgeShine 3.6s ease-in-out infinite;
  pointer-events:none;
}

@keyframes nfBadgePulse{
  0%,100%{
    box-shadow:
      0 10px 24px rgba(0,0,0,.24),
      0 0 18px rgba(124,58,237,.16);
  }
  50%{
    box-shadow:
      0 14px 30px rgba(0,0,0,.28),
      0 0 30px rgba(56,189,248,.22);
  }
}

@keyframes nfBadgeShine{
  0%{
    transform:translateX(-130%);
    opacity:0;
  }
  18%{
    opacity:.75;
  }
  55%{
    opacity:.25;
  }
  100%{
    transform:translateX(130%);
    opacity:0;
  }
}

/* Dropdown / input glow */
.neworder .form-control{
  transition:
    border-color .22s ease,
    box-shadow .22s ease,
    transform .22s ease;
}

.neworder .form-control:focus{
  transform:translateY(-1px);
  box-shadow:
    0 0 0 4px rgba(124,58,237,.14),
    0 14px 32px rgba(0,0,0,.18) !important;
}

/* Dynamic fields fade in */
.neworder #fields{
  animation:nfFieldFade .35s ease both;
}

.neworder #fields .form-group{
  animation:nfFieldFade .35s ease both;
}

@keyframes nfFieldFade{
  from{
    opacity:0;
    transform:translateY(8px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

/* Charge field highlight */
#charge{
  transition:
    box-shadow .25s ease,
    transform .25s ease !important;
}

#charge:focus,
#charge:hover{
  transform:translateY(-1px);
  box-shadow:
    0 0 0 4px rgba(34,197,94,.12),
    0 12px 28px rgba(34,197,94,.14) !important;
}

/* Submit button premium shine */
.neworder .dash-btn{
  position:relative;
  overflow:hidden;
  isolation:isolate;
}

.neworder .dash-btn::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(
    110deg,
    transparent 0%,
    rgba(255,255,255,.25) 42%,
    transparent 70%
  );
  transform:translateX(-130%);
  transition:transform .8s ease;
  pointer-events:none;
}

.neworder .dash-btn:hover::before{
  transform:translateX(130%);
}

.neworder .dash-btn:hover{
  transform:translateY(-3px);
}

/* Quick tips floating */
.neworder .col-sm-5 .well{
  animation:nfSideFloat 5.8s ease-in-out infinite;
}

.neworder .col-sm-5 .well:nth-child(2){
  animation-delay:.9s;
}

@keyframes nfSideFloat{
  0%,100%{
    transform:translateY(0);
  }
  50%{
    transform:translateY(-5px);
  }
}

/* Reduce motion for accessibility */
@media (prefers-reduced-motion: reduce){
  .neworder,
  .neworder *,
  .neworder *::before,
  .neworder *::after{
    animation:none !important;
    transition:none !important;
  }
}

/* Mobile: less movement */
@media(max-width:600px){
  .neworder .stat-wrap .media:hover,
  .neworder .dash-btn:hover{
    transform:none;
  }

  .neworder .col-sm-5 .well{
    animation:none;
  }
}
/* =========================================
   MOBILE BOTTOM NAVIGATION
   Frontend-only mobile UX upgrade
   ========================================= */

.nf-mobile-bottom-nav{
  display:none;
}

@media(max-width:991px){
  body.auth{
    padding-bottom:82px !important;
  }

  .nf-mobile-bottom-nav{
    position:fixed;
    left:10px;
    right:10px;
    bottom:10px;
    z-index:99990;
    display:grid;
    grid-template-columns:repeat(5,1fr);
    gap:6px;
    padding:8px;
    border-radius:24px;
    background:rgba(5,8,22,.86);
    border:1px solid rgba(167,139,250,.24);
    box-shadow:
      0 18px 48px rgba(0,0,0,.42),
      inset 0 1px 0 rgba(255,255,255,.06);
    backdrop-filter:blur(18px);
  }

  .nf-mobile-nav-item{
    min-height:54px;
    border-radius:17px;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:4px;
    color:#cbd6f7 !important;
    font-size:10px;
    font-weight:800;
    text-decoration:none !important;
    transition:.22s ease;
  }

  .nf-mobile-nav-item i{
    font-size:17px;
    line-height:1;
  }

  .nf-mobile-nav-item span{
    line-height:1;
    white-space:nowrap;
  }

  .nf-mobile-nav-item:hover,
  .nf-mobile-nav-item:focus{
    color:#fff !important;
    background:rgba(124,58,237,.18);
    transform:translateY(-2px);
  }

  .nf-mobile-nav-main{
    color:#fff !important;
    background:linear-gradient(135deg,#7c3aed,#2563eb,#06b6d4);
    box-shadow:0 10px 24px rgba(124,58,237,.28);
  }

  .nf-mobile-nav-main:hover,
  .nf-mobile-nav-main:focus{
    background:linear-gradient(135deg,#8b5cf6,#2563eb,#22d3ee);
  }
}

@media(max-width:380px){
  .nf-mobile-bottom-nav{
    left:6px;
    right:6px;
    bottom:6px;
    gap:4px;
    padding:6px;
    border-radius:20px;
  }

  .nf-mobile-nav-item{
    min-height:50px;
    font-size:9px;
    border-radius:14px;
  }

  .nf-mobile-nav-item i{
    font-size:15px;
  }
}
/* =========================================
   PWA-ish MOBILE POLISH
   App-like mobile browser experience
   ========================================= */

:root{
  --nf-safe-bottom: env(safe-area-inset-bottom, 0px);
  --nf-safe-top: env(safe-area-inset-top, 0px);
}

html{
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
}

body{
  -webkit-tap-highlight-color:transparent;
  overscroll-behavior-y:none;
}

button,
a,
select,
input,
textarea{
  touch-action:manipulation;
}

@media(max-width:600px){
  input,
  select,
  textarea{
    font-size:16px !important;
  }
}

@media(max-width:991px){
  body.auth,
  body.nf-theme{
    padding-bottom:calc(82px + var(--nf-safe-bottom)) !important;
  }

  .nf-topbar,
  .nf-public-nav{
    padding-top:calc(10px + var(--nf-safe-top)) !important;
  }

  .nf-mobile-bottom-nav{
    bottom:calc(10px + var(--nf-safe-bottom)) !important;
  }
}

@media(max-width:991px){
  .nf-content,
  .container-fluid{
    padding-left:14px !important;
    padding-right:14px !important;
  }

  .well,
  .panel,
  .media{
    border-radius:22px !important;
  }

  .table-responsive{
    border-radius:18px;
    overflow:auto;
    -webkit-overflow-scrolling:touch;
  }

  .form-control,
  .dash-btn,
  .btn{
    min-height:46px;
  }
}

body.nf-theme{
  animation:nfAppShellFade .35s ease both;
}

@keyframes nfAppShellFade{
  from{
    opacity:.86;
    transform:translateY(4px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

.nf-mobile-install-hint{
  display:none;
}

@media(max-width:991px){
  .nf-mobile-install-hint{
    position:fixed;
    left:12px;
    right:12px;
    bottom:calc(92px + var(--nf-safe-bottom));
    z-index:99980;
    display:flex;
    align-items:center;
    gap:12px;
    padding:12px 14px;
    border-radius:22px;
    background:rgba(5,8,22,.92);
    border:1px solid rgba(167,139,250,.24);
    box-shadow:
      0 18px 48px rgba(0,0,0,.42),
      inset 0 1px 0 rgba(255,255,255,.06);
    backdrop-filter:blur(18px);
    transform:translateY(130%);
    opacity:0;
    pointer-events:none;
    transition:.35s ease;
  }

  .nf-mobile-install-hint.show{
    transform:translateY(0);
    opacity:1;
    pointer-events:auto;
  }

  .nf-install-icon{
    width:42px;
    height:42px;
    min-width:42px;
    border-radius:15px;
    display:flex;
    align-items:center;
    justify-content:center;
    color:#fff;
    background:linear-gradient(135deg,#7c3aed,#2563eb,#06b6d4);
    box-shadow:0 10px 24px rgba(124,58,237,.28);
  }

  .nf-install-text{
    flex:1;
    min-width:0;
  }

  .nf-install-text strong{
    display:block;
    color:#fff;
    font-size:13px;
    font-weight:900;
    line-height:1.2;
  }

  .nf-install-text span{
    display:block;
    color:#9aa8c7;
    font-size:11px;
    font-weight:600;
    line-height:1.35;
  }

  .nf-install-close{
    width:30px;
    height:30px;
    min-width:30px;
    border:0;
    border-radius:50%;
    color:#fff;
    background:rgba(255,255,255,.08);
    font-size:20px;
    line-height:1;
  }
}

body.nf-standalone .nf-mobile-install-hint{
  display:none !important;
}

@media(max-width:991px){
  ::-webkit-scrollbar{
    width:6px;
    height:6px;
  }

  ::-webkit-scrollbar-thumb{
    background:rgba(167,139,250,.35);
    border-radius:999px;
  }

  ::-webkit-scrollbar-track{
    background:rgba(255,255,255,.04);
  }
}

.nf-mobile-nav-item:active,
.dash-btn:active,
.btn:active,
.nf-filter-chip:active{
  transform:scale(.97) !important;
}

.nf-mobile-bottom-nav .nf-mobile-nav-item.active{
  color:#fff !important;
  background:rgba(124,58,237,.22);
}

.nf-mobile-bottom-nav .nf-mobile-nav-main.active{
  background:linear-gradient(135deg,#8b5cf6,#2563eb,#22d3ee);
}

@media(max-width:991px){
  .nf-mobile-bottom-nav{
    padding-bottom:calc(8px + var(--nf-safe-bottom)) !important;
  }

  .nf-mobile-nav-item{
    user-select:none;
    -webkit-user-select:none;
  }
}

@media (prefers-reduced-motion: reduce){
  body.nf-theme,
  body.nf-theme *,
  body.nf-theme *::before,
  body.nf-theme *::after{
    animation:none !important;
    transition:none !important;
  }
}
/* =========================================
   FIX MOBILE BOTTOM NAV - ALWAYS STICKY/FIXED
   ========================================= */

@media(max-width:991px){
  .nf-mobile-bottom-nav{
    position:fixed !important;
    left:10px !important;
    right:10px !important;
    bottom:calc(10px + env(safe-area-inset-bottom, 0px)) !important;
    z-index:999999 !important;

    display:grid !important;
    grid-template-columns:repeat(5,1fr) !important;
    gap:6px !important;

    padding:8px !important;
    border-radius:24px !important;

    background:rgba(5,8,22,.92) !important;
    border:1px solid rgba(167,139,250,.28) !important;
    box-shadow:
      0 18px 48px rgba(0,0,0,.45),
      inset 0 1px 0 rgba(255,255,255,.08) !important;
    backdrop-filter:blur(18px) !important;
    -webkit-backdrop-filter:blur(18px) !important;

    transform:none !important;
    opacity:1 !important;
    pointer-events:auto !important;
  }

  .nf-mobile-nav-item{
    min-height:54px !important;
    border-radius:17px !important;

    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:center !important;
    gap:4px !important;

    color:#cbd6f7 !important;
    font-size:10px !important;
    font-weight:800 !important;
    text-decoration:none !important;

    transition:.22s ease !important;
  }

  .nf-mobile-nav-item i{
    font-size:17px !important;
    line-height:1 !important;
  }

  .nf-mobile-nav-item span{
    line-height:1 !important;
    white-space:nowrap !important;
  }

  .nf-mobile-nav-item:hover,
  .nf-mobile-nav-item:focus,
  .nf-mobile-nav-item.active{
    color:#fff !important;
    background:rgba(124,58,237,.22) !important;
  }

  .nf-mobile-nav-main{
    color:#fff !important;
    background:linear-gradient(135deg,#7c3aed,#2563eb,#06b6d4) !important;
    box-shadow:0 10px 24px rgba(124,58,237,.28) !important;
  }

  .nf-mobile-nav-main.active{
    background:linear-gradient(135deg,#8b5cf6,#2563eb,#22d3ee) !important;
  }

  body.auth,
  body.nf-theme{
    padding-bottom:calc(92px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .nf-footer{
    padding-bottom:calc(110px + env(safe-area-inset-bottom, 0px)) !important;
  }
}

@media(min-width:992px){
  .nf-mobile-bottom-nav{
    display:none !important;
  }
}

@media(max-width:380px){
  .nf-mobile-bottom-nav{
    left:6px !important;
    right:6px !important;
    bottom:calc(6px + env(safe-area-inset-bottom, 0px)) !important;
    gap:4px !important;
    padding:6px !important;
    border-radius:20px !important;
  }

  .nf-mobile-nav-item{
    min-height:50px !important;
    font-size:9px !important;
    border-radius:14px !important;
  }

  .nf-mobile-nav-item i{
    font-size:15px !important;
  }
}
/* =========================================
   FINAL FIX MOBILE BOTTOM NAV
   Remove body transform conflict + force fixed
   ========================================= */

/* Important: body transform can break position:fixed */
html,
body{
  transform:none !important;
}

body.nf-theme{
  animation:none !important;
  transform:none !important;
}

/* Force bottom nav to viewport */
#nfMobileBottomNav,
.nf-mobile-bottom-nav{
  position:fixed !important;
  left:10px !important;
  right:10px !important;
  bottom:10px !important;
  top:auto !important;

  z-index:2147483647 !important;

  display:grid !important;
  grid-template-columns:repeat(5,1fr) !important;
  gap:6px !important;

  padding:8px !important;
  border-radius:24px !important;

  background:rgba(5,8,22,.94) !important;
  border:1px solid rgba(167,139,250,.28) !important;
  box-shadow:
    0 18px 48px rgba(0,0,0,.45),
    inset 0 1px 0 rgba(255,255,255,.08) !important;

  backdrop-filter:blur(18px) !important;
  -webkit-backdrop-filter:blur(18px) !important;

  transform:none !important;
  opacity:1 !important;
  pointer-events:auto !important;
  visibility:visible !important;
}

/* Hide on desktop */
@media(min-width:992px){
  #nfMobileBottomNav,
  .nf-mobile-bottom-nav{
    display:none !important;
  }
}

/* Show on mobile */
@media(max-width:991px){
  body.auth,
  body.nf-theme{
    padding-bottom:110px !important;
  }

  #nfMobileBottomNav,
  .nf-mobile-bottom-nav{
    display:grid !important;
    bottom:calc(10px + env(safe-area-inset-bottom, 0px)) !important;
  }

  #nfMobileBottomNav .nf-mobile-nav-item,
  .nf-mobile-bottom-nav .nf-mobile-nav-item{
    min-height:54px !important;
    border-radius:17px !important;

    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
    justify-content:center !important;
    gap:4px !important;

    color:#cbd6f7 !important;
    font-size:10px !important;
    font-weight:800 !important;
    text-decoration:none !important;
    line-height:1 !important;
  }

  #nfMobileBottomNav .nf-mobile-nav-item i,
  .nf-mobile-bottom-nav .nf-mobile-nav-item i{
    font-size:17px !important;
    line-height:1 !important;
  }

  #nfMobileBottomNav .nf-mobile-nav-item span,
  .nf-mobile-bottom-nav .nf-mobile-nav-item span{
    line-height:1 !important;
    white-space:nowrap !important;
  }

  #nfMobileBottomNav .nf-mobile-nav-item.active,
  .nf-mobile-bottom-nav .nf-mobile-nav-item.active{
    color:#fff !important;
    background:rgba(124,58,237,.22) !important;
  }

  #nfMobileBottomNav .nf-mobile-nav-main,
  .nf-mobile-bottom-nav .nf-mobile-nav-main{
    color:#fff !important;
    background:linear-gradient(135deg,#7c3aed,#2563eb,#06b6d4) !important;
    box-shadow:0 10px 24px rgba(124,58,237,.28) !important;
  }
}

@media(max-width:380px){
  #nfMobileBottomNav,
  .nf-mobile-bottom-nav{
    left:6px !important;
    right:6px !important;
    bottom:calc(6px + env(safe-area-inset-bottom, 0px)) !important;
    gap:4px !important;
    padding:6px !important;
    border-radius:20px !important;
  }

  #nfMobileBottomNav .nf-mobile-nav-item,
  .nf-mobile-bottom-nav .nf-mobile-nav-item{
    min-height:50px !important;
    font-size:9px !important;
    border-radius:14px !important;
  }
}