/* Google Fonts (global) */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+SC:wght@400;500;600;700;800&family=Poppins:wght@300;400;500;600;700;800&display=swap');

:root{
  --font-main: "Poppins", "Noto Sans SC", system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
}
html, body{
  font-family: var(--font-main);
}

html, body{
  width: 100%;
  overflow-x: hidden !important;
}


:root{
  --brand-blue:#1b3a6b;
  --brand-orange:#f36b21;
  --text:#1f2937;
  --muted:#6b7280;
  --bg:#f7f9fc;
}

body{ color:var(--text); }
.navbar{ box-shadow: 0 8px 20px rgba(0,0,0,.06); }
.brand-dot{ color:var(--brand-orange); }
.hero{
  background: linear-gradient(120deg, rgba(27,58,107,.92), rgba(27,58,107,.72)),
              url("assets/img/hero.jpg") center/cover no-repeat;
  color:#fff;
  padding: 90px 0;
  overflow-x: hidden !important;
}
.hero .lead{ color: rgba(255,255,255,.85); }
.section{ padding: 70px 0; }
.section.bg{ background:var(--bg); }

.badge-soft{
  background: rgba(243,107,33,.12);
  color: var(--brand-orange);
  border: 1px solid rgba(243,107,33,.20);
}

.card{ border:0; box-shadow: 0 10px 26px rgba(0,0,0,.06); }
.icon-circle{
  width:44px;height:44px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  background: rgba(27,58,107,.10);
  color: var(--brand-blue);
  font-weight:700;
}

.footer{
  background:#0b1e3d;
  color:rgba(255,255,255,.85);
}
.footer a{ color:rgba(255,255,255,.85); text-decoration:none; }
.footer a:hover{ color:#fff; }

.small-muted{ color:var(--muted); }
.lang-btn{
  border:1px solid rgba(255,255,255,.25);
  color:#fff;
}
.lang-btn:hover{ background: rgba(255,255,255,.12); color:#fff; }
.hero .lang-btn{ border-color: rgba(255,255,255,.35); }

.page-hero{
  background: linear-gradient(120deg, rgba(27,58,107,.95), rgba(27,58,107,.75));
  color:#fff;
  padding: 50px 0;
}

img.rounded-soft{ border-radius: 18px; }
.btn-primary{
  background-color: #f36b21;
  border: #f36b21;
}
.btn-primary:hover{
  background-color: #3E4095;
  border: #3E4095;
}

.btn-outline-primary{
  color: #000000;
  border-color:#000000;

}
.btn-outline-primary:hover{
   background-color: #f36b21;
  border: #f36b21;
  
}
/* --- Motion + polish --- */
html { scroll-behavior: smooth; }
.btn, .card, .nav-link { transition: all .25s ease; }
.card:hover { transform: translateY(-4px); box-shadow: 0 16px 34px rgba(0,0,0,.10); }

.hero-v2{
  background: radial-gradient(1200px 600px at 15% 20%, rgba(243,107,33,.22), transparent 55%),
              radial-gradient(900px 500px at 80% 25%, rgba(255,255,255,.10), transparent 50%),
              linear-gradient(120deg, rgba(11,30,61,.98), rgba(27,58,107,.82)),
              url("assets/img/hero.jpg") center/cover no-repeat;
  color:#fff;
  padding: 92px 0;
  position: relative;
  overflow: hidden;
}

.hero-v2::after{
  content:"";
  position:absolute; inset:-120px -120px auto auto;
  width: 360px; height: 360px; border-radius: 50%;
  background: radial-gradient(circle, rgba(243,107,33,.35), transparent 60%);
  filter: blur(6px);
  animation: floaty 8s ease-in-out infinite;
}

@keyframes floaty{
  0%,100% { transform: translate(0,0); }
  50% { transform: translate(-18px, 18px); }
}

.section-title{
  font-weight:800;
  letter-spacing:-.4px;
}
.kpi{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px;
}
.kpi .num{ font-size: 28px; font-weight:800; }
.kpi .lbl{ color: rgba(255,255,255,.82); font-size: 13px; }

.pill{
  display:inline-flex; gap:8px; align-items:center;
  border-radius: 999px;
  padding: 6px 12px;
  background: rgba(243,107,33,.14);
  border: 1px solid rgba(243,107,33,.20);
  color: #ffd7bf;
}

.bg-grid{
  background:
    radial-gradient(circle at 1px 1px, rgba(27,58,107,.14) 1px, transparent 1px) 0 0/22px 22px;
}

/* ---------- Premium Navbar Styling ---------- */
.navbar{
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

/* Brand */
.navbar-brand span{
  letter-spacing: .2px;
}
.navbar-brand img{
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.25));
  height:150px;
}

/* Nav links */
.navbar-dark .navbar-nav .nav-link{
  color: rgba(255,255,255,.85);
  padding: 10px 7px;
  border-radius:0px;
  margin: 0 2px;
  position: relative;
  font-weight: 500;
}

/* Hover effect */
.navbar-dark .navbar-nav .nav-link:hover{
  color:#fff;
  background: rgba(255,255,255,.10);
  transform: translateY(-1px);
}

/* Active link pill */
.navbar-dark .navbar-nav .nav-link.active{
  color:#fff;
  background: rgba(243,107,33,.18);
  border: 1px solid rgba(243,107,33,.25);
  box-shadow: 0 10px 22px rgba(0,0,0,.20);
}

/* Mobile menu spacing */
@media (max-width: 991px){
  .navbar-dark .navbar-nav .nav-link{
    border-radius: 12px;
    padding: 12px 12px;
    margin: 3px 0;
  }
}


/* Certificates image polish */
.cert-img{
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 18px 40px rgba(0,0,0,.12);
  transition: transform .25s ease, box-shadow .25s ease;
}
.cert-img:hover{
  transform: translateY(-3px);
  box-shadow: 0 26px 60px rgba(0,0,0,.16);
}


/* Floating PPT Button */
.floating-ppt{
  position: fixed;
  right: 18px;          /* change to left:18px; if you want on left */
  bottom: 18px;
  z-index: 9999;

  display: inline-flex;
  align-items: center;
  gap: 10px;

  padding: 12px 14px;
  border-radius: 999px;

  background: rgba(11,30,61,.92);
  color: #fff;
  text-decoration: none;

  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 16px 40px rgba(0,0,0,.22);
  backdrop-filter: blur(8px);

  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.floating-ppt:hover{
  transform: translateY(-2px);
  box-shadow: 0 22px 60px rgba(0,0,0,.28);
  background: rgba(11,30,61,.98);
  color: #fff;
}

.ppt-icon{
  width: 34px;
  height: 34px;
  border-radius: 50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 800;
  background: rgba(243,107,33,.95);
  box-shadow: 0 10px 25px rgba(243,107,33,.25);
}

.ppt-text{
  font-weight: 600;
  font-size: 14px;
  letter-spacing: .2px;
}

@media (max-width: 420px){
  .ppt-text{ display:none; } /* icon only on small screens */
  .floating-ppt{ padding: 10px; }
}

@media (max-width: 420px){
  .navbar-brand img{
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.25));
  height:100px;
}
}
.navbar-brand span{
    display:none !important;
}

/*videos*/

/* ===== Media Gallery Premium UI ===== */
.media-hero{
  position: relative;
  overflow: hidden;
  padding: 70px 0 40px;
  background: radial-gradient(1200px 600px at 10% 10%, rgba(243,107,33,.20), transparent 55%),
              radial-gradient(1000px 500px at 90% 30%, rgba(64,140,255,.16), transparent 55%),
              linear-gradient(180deg, #07162e 0%, #0b1e3d 45%, #07162e 100%);
  color: #fff;
}
.media-hero .lead{ color: rgba(255,255,255,.78); }
.media-chip{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 14px; border-radius:999px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
}

.media-stats{
  display:flex; gap:10px; flex-wrap:wrap; margin-top:16px;
}
.media-stat{
  padding:10px 12px; border-radius:14px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  min-width: 140px;
}
.media-stat b{ display:block; font-size:18px; }
.media-stat span{ font-size:12px; color: rgba(255,255,255,.70); }

.media-toolbar{
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 18px;
  padding: 12px;
}
.media-search{
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  color:#fff !important;
}
.media-search::placeholder{ color: rgba(255,255,255,.55); }

.media-card{
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 18px 50px rgba(0,0,0,.14);
  background: #0b1e3d;
  transition: transform .2s ease, box-shadow .2s ease;
  cursor: pointer;
}
.media-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 28px 70px rgba(0,0,0,.20);
}
.media-thumb{
  position: relative;
  aspect-ratio: 16/9;
  background: linear-gradient(135deg, rgba(243,107,33,.18), rgba(64,140,255,.18));
}
.media-thumb video{
  width:100%; height:100%;
  object-fit: cover;
  filter: contrast(1.02) saturate(1.05);
}
.media-overlay{
  position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.0) 30%, rgba(0,0,0,.55) 100%);
}
.play-badge{
  position:absolute; left:14px; top:14px;
  display:inline-flex; align-items:center; justify-content:center;
  width:44px; height:44px; border-radius:50%;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.22);
  backdrop-filter: blur(8px);
}
.play-badge::before{
  content:"";
  display:block;
  width:0; height:0;
  border-left: 12px solid #fff;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  margin-left:3px;
}
.media-meta{
  position:absolute; left:0; right:0; bottom:0;
  padding: 12px 14px;
  display:flex; align-items:end; justify-content:space-between; gap:10px;
}
.media-title{
  color:#fff; font-weight: 700;
  line-height: 1.2;
}
.media-sub{
  color: rgba(255,255,255,.70);
  font-size: 12px;
  margin-top: 4px;
}
.media-tag{
  font-size: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.12);
  color:#fff;
  white-space: nowrap;
}

/* Featured carousel */
.featured-wrap{
  border-radius: 22px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 22px 70px rgba(0,0,0,.22);
  background: rgba(255,255,255,.04);
}
.featured-caption{
  position:absolute; left:18px; right:18px; bottom:18px;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(0,0,0,.38);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
}
.featured-caption h5{ margin:0; color:#fff; font-weight: 800; }
.featured-caption p{ margin:6px 0 0; color: rgba(255,255,255,.78); font-size: 13px; }

/* Modal video */
.modal-video{
  width: 100%;
  max-height: 78vh;
  border-radius: 16px;
  background:#000;
}

.media-thumb video{
  pointer-events: none; /* ✅ tap opens modal instead of playing preview */
}


/* Compact on mobile */
@media (max-width: 576px){
  .media-hero{ padding: 56px 0 30px; }
  .media-stat{ min-width: 46%; }
}

