/* ================================================================
   Shiva Digital Academy — Complete Stylesheet v2
   Premium, customer-focused, reference: neist.in (improved)
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Poppins:wght@600;700;800;900&display=swap');

/* ── Design Tokens ─────────────────────────────────────────── */
:root {
  --blue:        #1565c0;
  --blue-dark:   #0d3c7a;
  --blue-mid:    #1976d2;
  --blue-light:  #e3f0ff;
  --blue-xlight: #f0f7ff;
  --orange:      #f57c00;
  --orange-dark: #e65100;
  --orange-light:#fff3e0;
  --purple:      #6a1b9a;
  --purple-light:#f3e5f5;
  --teal:        #00796b;
  --teal-light:  #e0f2f1;
  --red:         #c62828;
  --green:       #2e7d32;
  --green-light: #f0fdf4;
  --yellow:      #f9a825;

  --dark:        #0f172a;
  --dark-2:      #1e293b;
  --dark-3:      #334155;
  --body-bg:     #f4f7fc;
  --card-bg:     #ffffff;
  --border:      #e2e8f0;
  --border-dark: #cbd5e1;
  --text:        #1e293b;
  --text-soft:   #475569;
  --text-muted:  #94a3b8;

  --radius:      10px;
  --radius-lg:   16px;
  --radius-xl:   24px;
  --shadow-xs:   0 1px 4px rgba(0,0,0,.06);
  --shadow-sm:   0 2px 10px rgba(0,0,0,.08);
  --shadow:      0 6px 24px rgba(0,0,0,.10);
  --shadow-lg:   0 16px 48px rgba(0,0,0,.14);
  --shadow-xl:   0 24px 64px rgba(0,0,0,.18);
  --t:           all .28s cubic-bezier(.4,0,.2,1);
}

/* ── Reset / Base ──────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; }
body { font-family:'Inter',sans-serif; background:var(--body-bg); color:var(--text); line-height:1.65; overflow-x:hidden; }
h1,h2,h3,h4,h5,h6 { font-family:'Poppins',sans-serif; font-weight:700; line-height:1.25; }
a { text-decoration:none; transition:var(--t); }
img { max-width:100%; }
main { min-height:calc(100vh - 420px); }

/* ── Utility ───────────────────────────────────────────────── */
.fw-800{font-weight:800!important} .fw-900{font-weight:900!important}
.text-blue{color:var(--blue)!important} .text-orange{color:var(--orange)!important}
.text-purple{color:var(--purple)!important} .text-teal{color:var(--teal)!important}
.bg-blue-xlight{background:var(--blue-xlight)!important}

/* ── Section Heading ───────────────────────────────────────── */
.section-heading { text-align:center; margin-bottom:3rem; }
.section-heading .badge-label {
  display:inline-flex; align-items:center; gap:6px;
  font-size:.72rem; font-weight:700; letter-spacing:1.8px; text-transform:uppercase;
  padding:5px 16px; border-radius:50px; margin-bottom:.7rem;
}
.badge-label-orange { color:var(--orange); background:var(--orange-light); }
.badge-label-blue   { color:var(--blue);   background:var(--blue-light);   }
.badge-label-purple { color:var(--purple); background:var(--purple-light); }
.badge-label-teal   { color:var(--teal);   background:var(--teal-light);   }
.badge-label-green  { color:var(--green);  background:var(--green-light);  }
.section-heading h2 { font-size:clamp(1.7rem,3vw,2.5rem); color:var(--dark); margin-bottom:.5rem; }
.section-heading p  { color:var(--text-soft); max-width:580px; margin:0 auto; font-size:.97rem; }
.divider { width:50px; height:4px; background:linear-gradient(90deg,var(--blue),var(--orange)); border-radius:2px; margin:.9rem auto 0; }
.section-pad    { padding:86px 0; }
.section-pad-sm { padding:52px 0; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   ANNOUNCEMENT BAR
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.announce-bar {
  background:linear-gradient(90deg,var(--orange-dark),var(--orange),#ff8f00,var(--orange-dark));
  background-size:300% 100%;
  animation:announceBG 8s linear infinite;
  padding:7px 0;
  position:relative; overflow:hidden;
}
@keyframes announceBG {
  0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%}
}
.announce-bar .ticker-wrap {
  overflow:hidden; white-space:nowrap;
  display:flex; align-items:center; gap:0;
}
.announce-bar .ticker-track {
  display:inline-flex; align-items:center; gap:0;
  animation:tickerMove 35s linear infinite;
}
.announce-bar .ticker-track:hover { animation-play-state:paused; }
@keyframes tickerMove { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
.announce-bar .tick-item {
  display:inline-flex; align-items:center; gap:8px;
  font-size:.78rem; font-weight:600; color:#fff;
  padding:0 2.5rem;
  white-space:nowrap;
}
.announce-bar .tick-item i { font-size:.8rem; }
.announce-bar .tick-sep {
  color:rgba(255,255,255,.45); font-size:.6rem;
}
.announce-close {
  position:absolute; right:12px; top:50%; transform:translateY(-50%);
  background:rgba(255,255,255,.2); border:none; color:#fff;
  width:22px; height:22px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:.7rem; cursor:pointer; transition:var(--t);
}
.announce-close:hover { background:rgba(255,255,255,.35); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   UTILITY BAR
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.utility-bar {
  background:var(--dark-2);
  padding:6px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.utility-bar .util-left,
.utility-bar .util-right {
  display:flex; align-items:center; gap:1.2rem; flex-wrap:wrap;
}
.utility-bar .util-item {
  display:flex; align-items:center; gap:6px;
  font-size:.76rem; color:rgba(255,255,255,.6);
}
.utility-bar .util-item i { color:var(--orange); font-size:.72rem; }
.utility-bar .util-link {
  display:flex; align-items:center; gap:6px;
  font-size:.76rem; font-weight:600; color:rgba(255,255,255,.75);
  padding:2px 10px; border-radius:4px;
  transition:var(--t);
}
.utility-bar .util-link:hover { color:#fff; background:rgba(255,255,255,.08); }
.utility-bar .util-link.highlight {
  color:var(--orange); border:1px solid rgba(245,124,0,.35);
}
.utility-bar .util-link.highlight:hover { background:rgba(245,124,0,.12); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SUB-NAVBAR (Jobs / Scholarships / Results)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.sub-navbar {
  background:#fff;
  border-bottom:2px solid var(--border);
  position:sticky; top:57px; z-index:1040;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
}
.sub-navbar .container {
  display:flex; align-items:stretch; overflow-x:auto;
  scrollbar-width:none; gap:0;
}
.sub-navbar .container::-webkit-scrollbar { display:none; }

.snav-item {
  display:inline-flex; align-items:center; gap:7px;
  padding:.65rem 1.4rem;
  font-size:.82rem; font-weight:700;
  color:var(--text-soft);
  border-bottom:3px solid transparent;
  white-space:nowrap; transition:var(--t);
  text-decoration:none; flex-shrink:0;
}
.snav-item i { font-size:.85rem; }
.snav-item:hover { color:var(--dark); background:var(--body-bg); }

/* Each button gets its own accent colour */
.snav-item:nth-child(1)       { --snav-color:#f57c00; }
.snav-item:nth-child(1):hover,
.snav-item:nth-child(1).active{ color:var(--snav-color); border-bottom-color:var(--snav-color); background:rgba(245,124,0,.06); }

.snav-item:nth-child(2)       { --snav-color:#7c3aed; }
.snav-item:nth-child(2):hover,
.snav-item:nth-child(2).active{ color:var(--snav-color); border-bottom-color:var(--snav-color); background:rgba(124,58,237,.06); }

.snav-item:nth-child(3)       { --snav-color:#0ea5e9; }
.snav-item:nth-child(3):hover,
.snav-item:nth-child(3).active{ color:var(--snav-color); border-bottom-color:var(--snav-color); background:rgba(14,165,233,.06); }

.snav-item:nth-child(4)       { --snav-color:#16a34a; }
.snav-item:nth-child(4):hover,
.snav-item:nth-child(4).active{ color:var(--snav-color); border-bottom-color:var(--snav-color); background:rgba(22,163,74,.06); }

.snav-item:nth-child(5)       { --snav-color:#e65100; }
.snav-item:nth-child(5):hover,
.snav-item:nth-child(5).active{ color:var(--snav-color); border-bottom-color:var(--snav-color); background:rgba(230,81,0,.06); }

@media (max-width:480px) {
  .snav-item { padding:.6rem .9rem; font-size:.78rem; }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   MAIN NAVBAR
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.site-navbar {
  background:rgba(13,60,122,.97);
  backdrop-filter:blur(12px);
  padding:.7rem 0;
  transition:var(--t);
  border-bottom:1px solid rgba(255,255,255,.07);
  position:sticky; top:0; z-index:1050;
}
.site-navbar.scrolled {
  background:rgba(13,60,122,1);
  box-shadow:0 4px 24px rgba(0,0,0,.28);
  padding:.5rem 0;
}
.navbar-brand {
  font-family:'Poppins',sans-serif;
  color:#fff!important;
  display:flex; align-items:center; gap:12px;
  text-decoration:none!important;
}

/* ── Brand icon ── */
.brand-icon-wrap {
  width:44px; height:44px; flex-shrink:0;
  background:linear-gradient(145deg,#f97316 0%,#fbbf24 100%);
  border-radius:13px;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 16px rgba(251,146,60,.55), 0 0 0 3px rgba(251,191,36,.18);
  position:relative;
}
.brand-icon-glyph { font-size:1.2rem; color:#fff; filter:drop-shadow(0 1px 3px rgba(0,0,0,.25)); }
.brand-favicon-img { width:28px; height:28px; object-fit:contain; display:block; }

/* ── Brand text ── */
.brand-text-wrap { display:flex; flex-direction:column; gap:1px; }
.brand-name-row  { display:flex; align-items:center; gap:7px; }

.brand-shiva {
  font-size:1.22rem; font-weight:900; letter-spacing:2px;
  background:linear-gradient(135deg,#fb923c 0%,#fde68a 60%,#fbbf24 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1;
}
.brand-vbar {
  width:1.5px; height:16px; background:rgba(255,255,255,.22);
  border-radius:2px; flex-shrink:0;
}
.brand-rest {
  font-size:.88rem; font-weight:600; color:rgba(255,255,255,.88);
  letter-spacing:.4px; line-height:1;
}
.brand-enterprise {
  font-size:.58rem; color:rgba(255,255,255,.3);
  letter-spacing:2px; text-transform:uppercase;
  font-weight:500; font-family:'Inter',sans-serif;
  padding-left:1px;
}
.site-navbar .nav-link {
  color:rgba(255,255,255,.82)!important; font-size:.85rem; font-weight:500;
  padding:.45rem .85rem!important; border-radius:7px; transition:var(--t);
}
.site-navbar .nav-link:hover,.site-navbar .nav-link.active {
  color:#fff!important; background:rgba(255,255,255,.12);
}
.nav-btn-login {
  background:linear-gradient(135deg,var(--orange),#ff8f00)!important;
  color:#fff!important; border-radius:8px; font-weight:700!important;
  padding:.45rem 1.2rem!important;
  box-shadow:0 4px 12px rgba(245,124,0,.4); transition:var(--t)!important;
}
.nav-btn-login:hover { transform:translateY(-1px); box-shadow:0 6px 18px rgba(245,124,0,.5)!important; }
.student-pill {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.15);
  border-radius:50px; padding:4px 14px 4px 5px; color:#fff;
}
.student-pill .ava {
  width:28px; height:28px; background:linear-gradient(135deg,var(--orange),#ff8f00);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:.75rem; font-weight:700;
}
.student-pill .name { font-size:.82rem; font-weight:600; }
.student-pill .logout-btn {
  color:rgba(255,255,255,.5); font-size:.8rem; margin-left:2px; transition:var(--t);
}
.student-pill .logout-btn:hover { color:#ff8a80; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   HERO
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.hero-section {
  background:linear-gradient(135deg,#050e2d 0%,#0d3c7a 45%,#1a237e 70%,#0d3c7a 100%);
  position:relative; overflow:hidden;
  min-height:calc(100vh - 110px);
  display:flex; flex-direction:column;
}
.hero-shapes { position:absolute; inset:0; pointer-events:none; }
.hero-shape {
  position:absolute; border-radius:50%;
  filter:blur(80px); opacity:.22;
  animation:shapeFloat 9s ease-in-out infinite alternate;
}
.hs1 { width:500px;height:500px;background:#3b82f6; top:-100px;right:-80px; }
.hs2 { width:350px;height:350px;background:var(--orange); bottom:60px;left:-80px; animation-delay:4s; }
.hs3 { width:250px;height:250px;background:#7c3aed; top:40%;left:35%; animation-delay:2s; opacity:.12; }
@keyframes shapeFloat { from{transform:translate(0,0) scale(1)} to{transform:translate(18px,-22px) scale(1.08)} }

/* Grid pattern overlay */
.hero-section::before {
  content:''; position:absolute; inset:0; opacity:.04;
  background-image:linear-gradient(rgba(255,255,255,.5) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.5) 1px,transparent 1px);
  background-size:40px 40px;
}
.hero-inner { position:relative; z-index:2; flex:1; display:flex; align-items:center; padding:90px 0 50px; }

/* Trust badges row */
.trust-badges { display:flex; align-items:center; gap:.8rem; flex-wrap:wrap; margin-bottom:1.6rem; }
.trust-badge {
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.14);
  color:rgba(255,255,255,.85); font-size:.73rem; font-weight:600;
  padding:5px 14px; border-radius:50px; letter-spacing:.3px;
}
.trust-badge i { color:var(--yellow); }
.trust-badge.featured { background:rgba(245,124,0,.15); border-color:rgba(245,124,0,.35); color:#ffd54f; }

/* Hero text */
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.9); font-size:.74rem; font-weight:700;
  letter-spacing:2px; text-transform:uppercase;
  padding:6px 16px; border-radius:50px; margin-bottom:1.2rem;
}
.hero-eyebrow i { color:var(--yellow); }
.hero-title {
  font-size:clamp(2rem,5vw,3.8rem); font-weight:900;
  color:#fff; line-height:1.1; margin-bottom:1.2rem;
}
.hero-title .highlight {
  background:linear-gradient(90deg,#ffd54f,#ff8f00);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.hero-subtitle { font-size:.97rem; color:rgba(255,255,255,.72); max-width:520px; line-height:1.75; margin-bottom:1.8rem; }

/* Buttons */
.btn-hero-primary {
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg,var(--orange),#ff8f00);
  color:#fff; border:none; padding:.85rem 2rem;
  border-radius:10px; font-weight:700; font-size:.97rem;
  box-shadow:0 8px 24px rgba(245,124,0,.45); transition:var(--t); cursor:pointer;
}
.btn-hero-primary:hover { transform:translateY(-2px); box-shadow:0 12px 32px rgba(245,124,0,.55); color:#fff; }
.btn-hero-secondary {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.1); color:#fff; border:2px solid rgba(255,255,255,.28);
  padding:.85rem 2rem; border-radius:10px; font-weight:600; font-size:.97rem;
  transition:var(--t); backdrop-filter:blur(4px);
}
.btn-hero-secondary:hover { background:rgba(255,255,255,.18); border-color:rgba(255,255,255,.5); transform:translateY(-2px); color:#fff; }

/* Hero visual */
.hero-visual { position:relative; }
.hero-card-wrap { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.hcard {
  background:rgba(255,255,255,.08); backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.15); border-radius:var(--radius-lg);
  padding:1.5rem; color:#fff; transition:var(--t);
  animation:hcardFloat 5s ease-in-out infinite alternate;
}
.hcard:nth-child(2) { animation-delay:1.2s; margin-top:20px; }
.hcard:nth-child(3) { grid-column:span 2; animation-delay:2.4s; }
.hcard:hover { background:rgba(255,255,255,.13); }
@keyframes hcardFloat { from{transform:translateY(0)} to{transform:translateY(-10px)} }
.hcard .hc-icon {
  width:46px; height:46px; border-radius:12px;
  display:flex; align-items:center; justify-content:center; font-size:1.2rem;
  margin-bottom:.8rem;
}
.hcard .hc-val { font-size:2rem; font-weight:900; margin-bottom:.15rem; }
.hcard .hc-lbl { font-size:.72rem; opacity:.65; text-transform:uppercase; letter-spacing:1px; }
.hcard-wide { display:flex; align-items:center; gap:14px; }
.hcard-wide .hw-icon {
  width:44px; height:44px; background:linear-gradient(135deg,#1565c0,#42a5f5);
  border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0;
}
.hcard-wide .hw-icon i { color:#ffd54f; font-size:1.1rem; }
.hcard-wide .hw-title { font-weight:700; font-size:.95rem; }
.hcard-wide .hw-sub   { font-size:.75rem; opacity:.6; }

/* Hero stats bar */
.hero-statsbar {
  position:relative; z-index:2;
  background:rgba(255,255,255,.06); border-top:1px solid rgba(255,255,255,.09);
  padding:1.2rem 0;
}
.hstats-item { text-align:center; padding:.5rem; }
.hstats-item .hsnum {
  font-size:1.8rem; font-weight:900; display:block; line-height:1;
  background:linear-gradient(90deg,#ffd54f,#ff8f00);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.hstats-item .hslbl { font-size:.7rem; color:rgba(255,255,255,.55); text-transform:uppercase; letter-spacing:1.2px; margin-top:.3rem; }
.hstats-sep { width:1px; background:rgba(255,255,255,.1); align-self:stretch; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   QUICK SERVICES STRIP
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.services-strip {
  background:#fff; border-bottom:1px solid var(--border);
  padding:0;
}
.services-strip-inner {
  display:flex; overflow-x:auto; gap:0;
  scrollbar-width:none; -ms-overflow-style:none;
}
.services-strip-inner::-webkit-scrollbar { display:none; }
.strip-item {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:6px; padding:1.4rem 1.8rem;
  font-size:.78rem; font-weight:600; color:var(--text-soft);
  border-right:1px solid var(--border);
  cursor:default; transition:var(--t); white-space:nowrap; flex-shrink:0;
}
.strip-item:last-child { border-right:none; }
.strip-item:hover { background:var(--blue-xlight); color:var(--blue); }
.strip-item i { font-size:1.4rem; color:var(--blue); transition:var(--t); }
.strip-item:hover i { transform:scale(1.2); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SERVICES GRID
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.svc-card {
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:2rem 1.5rem; text-align:center; transition:var(--t); height:100%;
  position:relative; overflow:hidden;
}
.svc-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:3px;
  background:var(--svc-color,var(--blue)); transform:scaleX(0); transform-origin:left; transition:transform .35s ease;
}
.svc-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); }
.svc-card:hover::before { transform:scaleX(1); }
.svc-icon {
  width:70px; height:70px; border-radius:var(--radius);
  background:var(--svc-bg,var(--blue-light)); color:var(--svc-color,var(--blue));
  display:flex; align-items:center; justify-content:center;
  font-size:1.8rem; margin:0 auto 1.2rem; transition:var(--t);
}
.svc-card:hover .svc-icon { background:var(--svc-color,var(--blue)); color:#fff; transform:scale(1.1) rotate(-6deg); }
.svc-card h5 { font-size:.97rem; color:var(--dark); margin-bottom:.4rem; }
.svc-card p  { font-size:.83rem; color:var(--text-muted); margin:0; line-height:1.6; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   HOW TO ENROLL
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.enroll-section { background:linear-gradient(180deg,var(--blue-xlight) 0%,#fff 100%); }
.step-card {
  background:#fff; border-radius:var(--radius-lg); padding:2.2rem 2rem;
  text-align:center; transition:var(--t); height:100%;
  border:1px solid var(--border); position:relative;
}
.step-card:hover { box-shadow:var(--shadow-lg); transform:translateY(-5px); }
.step-num {
  width:60px; height:60px; border-radius:50%;
  background:linear-gradient(135deg,var(--blue),var(--blue-mid));
  color:#fff; font-size:1.5rem; font-weight:900; font-family:'Poppins',sans-serif;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 1.4rem; box-shadow:0 6px 20px rgba(21,101,192,.4);
  position:relative; z-index:1;
}
.step-card.step-2 .step-num { background:linear-gradient(135deg,var(--orange),#ff8f00); box-shadow:0 6px 20px rgba(245,124,0,.4); }
.step-card.step-3 .step-num { background:linear-gradient(135deg,var(--green),#43a047); box-shadow:0 6px 20px rgba(46,125,50,.4); }
.step-card h5 { font-size:1.05rem; color:var(--dark); margin-bottom:.5rem; }
.step-card p  { font-size:.86rem; color:var(--text-soft); margin:0; }
/* Connector arrow */
.step-connector {
  display:flex; align-items:center; justify-content:center;
  color:var(--border-dark); font-size:1.4rem; padding-top:30px;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   COURSE CARDS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.courses-section { background:var(--body-bg); }
.course-card {
  background:#fff; border-radius:var(--radius-xl); overflow:hidden;
  box-shadow:var(--shadow); transition:var(--t); height:100%;
}
.course-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-xl); }
.course-card.pro { border:2px solid var(--blue); }
.pop-badge {
  position:absolute; top:-1px; right:28px;
  background:linear-gradient(135deg,var(--orange),#ff8f00);
  color:#fff; font-size:.7rem; font-weight:800;
  padding:5px 18px; border-radius:0 0 12px 12px; letter-spacing:.5px; text-transform:uppercase;
}
.course-head {
  padding:2.2rem 2rem 1.8rem; color:#fff; text-align:center;
  background:linear-gradient(135deg,var(--blue-dark) 0%,var(--blue-mid) 100%);
}
.course-head.pro-head { background:linear-gradient(135deg,#3d007a 0%,var(--purple) 100%); }
.course-head .c-icon {
  width:68px; height:68px; border-radius:18px;
  background:rgba(255,255,255,.15); display:flex; align-items:center; justify-content:center;
  font-size:1.9rem; margin:0 auto .9rem;
}
.course-head h3 { font-size:1.7rem; font-weight:900; margin-bottom:.3rem; }
.course-head .dur { font-size:.8rem; opacity:.72; }
.course-head .price {
  font-size:2.5rem; font-weight:900; margin:.5rem 0 0;
  background:linear-gradient(90deg,#ffd54f,#fff);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.course-body { padding:1.8rem 2rem; }
.cf { display:flex; align-items:center; gap:10px; padding:.5rem 0; border-bottom:1px solid var(--border); font-size:.87rem; color:var(--text); }
.cf:last-child { border-bottom:none; }
.cf i { color:var(--green); font-size:.9rem; flex-shrink:0; }
.course-foot { padding:0 2rem 2rem; }
.btn-enroll {
  width:100%; padding:.9rem; border-radius:10px; font-weight:700; font-size:.95rem;
  border:none; transition:var(--t); cursor:pointer; display:flex; align-items:center; justify-content:center; gap:8px;
}
.enroll-basic { background:linear-gradient(135deg,var(--blue),var(--blue-mid)); color:#fff; box-shadow:0 4px 16px rgba(21,101,192,.35); }
.enroll-basic:hover { transform:translateY(-2px); box-shadow:0 8px 26px rgba(21,101,192,.48); color:#fff; }
.enroll-pro { background:linear-gradient(135deg,#4a0080,var(--purple)); color:#fff; box-shadow:0 4px 16px rgba(106,27,154,.35); }
.enroll-pro:hover { transform:translateY(-2px); box-shadow:0 8px 26px rgba(106,27,154,.48); color:#fff; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   STATS SECTION
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.stats-section {
  background:linear-gradient(135deg,#060f2a 0%,#0d3c7a 50%,#1a237e 100%);
  position:relative; overflow:hidden;
}
.stats-section::after {
  content:''; position:absolute; inset:0; opacity:.04;
  background-image:radial-gradient(circle,rgba(255,255,255,1) 1px,transparent 1px);
  background-size:30px 30px;
}
.stat-item { text-align:center; padding:1.5rem 1rem; position:relative; z-index:1; }
.stat-icon {
  width:56px; height:56px; border-radius:16px;
  background:rgba(255,255,255,.09); display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; color:rgba(255,255,255,.7); margin:0 auto .9rem;
}
.stat-num {
  font-size:clamp(2.2rem,5vw,3.4rem); font-weight:900; line-height:1; display:block;
  background:linear-gradient(90deg,#ffd54f,#ff8f00);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  margin-bottom:.4rem;
}
.stat-label { font-size:.78rem; color:rgba(255,255,255,.6); text-transform:uppercase; letter-spacing:1.5px; font-weight:500; }
.stat-sep { width:1px; background:rgba(255,255,255,.1); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   TESTIMONIALS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.testimonials-section { background:#fff; }
.testi-scroll {
  display:flex; gap:1.5rem; overflow-x:auto; padding:1rem .5rem 2rem;
  scroll-snap-type:x mandatory; scrollbar-width:thin; scrollbar-color:var(--border) transparent;
  cursor:grab;
}
.testi-scroll:active { cursor:grabbing; }
.testi-scroll::-webkit-scrollbar { height:4px; }
.testi-scroll::-webkit-scrollbar-track { background:transparent; }
.testi-scroll::-webkit-scrollbar-thumb { background:var(--border); border-radius:2px; }
.testi-card {
  min-width:300px; max-width:340px; flex-shrink:0;
  background:var(--body-bg); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:1.8rem;
  scroll-snap-align:start; transition:var(--t); user-select:none;
}
.testi-card:hover { box-shadow:var(--shadow); background:#fff; }
.testi-quote { font-size:2.5rem; color:var(--blue-light); line-height:1; margin-bottom:.5rem; font-family:'Georgia',serif; }
.testi-text { font-size:.88rem; color:var(--text-soft); line-height:1.7; margin-bottom:1.2rem; font-style:italic; }
.testi-stars { color:var(--yellow); font-size:.8rem; margin-bottom:1rem; letter-spacing:2px; }
.testi-author { display:flex; align-items:center; gap:12px; }
.testi-ava {
  width:44px; height:44px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:.9rem; font-weight:700; color:#fff; flex-shrink:0;
}
.testi-name { font-weight:700; font-size:.88rem; color:var(--dark); }
.testi-course {
  font-size:.74rem; display:inline-block;
  background:var(--blue-light); color:var(--blue);
  padding:2px 8px; border-radius:4px; font-weight:600; margin-top:2px;
}
/* Scroll buttons */
.testi-nav { display:flex; gap:8px; }
.testi-btn {
  width:38px; height:38px; border-radius:10px; border:1px solid var(--border);
  background:#fff; color:var(--text-soft); display:flex; align-items:center; justify-content:center;
  cursor:pointer; transition:var(--t); font-size:.85rem;
}
.testi-btn:hover { background:var(--blue); color:#fff; border-color:var(--blue); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PLACEMENTS / SUCCESS STORIES
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.placements-section { background:var(--body-bg); }
.placement-card {
  background:#fff; border-radius:var(--radius-lg); padding:1.5rem;
  border:1px solid var(--border); transition:var(--t);
  display:flex; flex-direction:column; align-items:center; text-align:center;
  height:100%;
}
.placement-card:hover { box-shadow:var(--shadow); transform:translateY(-4px); }
.p-ava {
  width:64px; height:64px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; font-weight:800; color:#fff; margin-bottom:1rem;
  box-shadow:0 4px 12px rgba(0,0,0,.15);
}
.p-name { font-size:.95rem; font-weight:700; color:var(--dark); margin-bottom:.2rem; }
.p-course { font-size:.72rem; font-weight:600; background:var(--blue-light); color:var(--blue); padding:2px 10px; border-radius:50px; margin-bottom:.9rem; display:inline-block; }
.p-arrow { color:var(--text-muted); font-size:.7rem; margin:.3rem 0; }
.p-company { font-size:.85rem; font-weight:600; color:var(--text); }
.p-role { font-size:.78rem; color:var(--text-muted); }
.placed-badge {
  display:inline-flex; align-items:center; gap:5px; margin-top:.8rem;
  background:linear-gradient(135deg,var(--green),#43a047); color:#fff;
  font-size:.7rem; font-weight:700; padding:4px 12px; border-radius:50px;
  text-transform:uppercase; letter-spacing:.5px;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LISTINGS (JOBS / SCHOLARSHIPS)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.listing-card {
  background:#fff; border-radius:var(--radius-lg); border:1px solid var(--border);
  overflow:hidden; transition:var(--t); height:100%;
}
.listing-card:hover { box-shadow:var(--shadow); transform:translateY(-4px); }
.listing-card .l-top { height:4px; background:linear-gradient(90deg,var(--blue),var(--orange)); }
.listing-card .l-body { padding:1.5rem; }
.l-type {
  display:inline-flex; align-items:center; gap:5px;
  font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.8px;
  padding:3px 10px; border-radius:4px; margin-bottom:.8rem;
}
.listing-card h5 { font-size:.97rem; font-weight:700; color:var(--dark); margin-bottom:.25rem; }
.l-org { font-size:.8rem; color:var(--text-muted); margin-bottom:.8rem; }
.l-desc { font-size:.84rem; color:var(--text-soft); line-height:1.6; margin-bottom:.9rem; }
.l-meta { display:flex; flex-wrap:wrap; gap:.4rem; margin-bottom:.8rem; }
.l-tag {
  display:inline-flex; align-items:center; gap:4px;
  font-size:.72rem; color:var(--text-muted); background:var(--body-bg);
  padding:3px 9px; border-radius:5px; border:1px solid var(--border);
}
.l-deadline {
  display:inline-flex; align-items:center; gap:5px;
  font-size:.72rem; font-weight:600; color:var(--red);
  background:#fff5f5; padding:3px 9px; border-radius:5px; border:1px solid #fecaca;
  margin-bottom:.8rem;
}
.btn-apply {
  font-size:.82rem; font-weight:700; padding:.5rem 1.2rem;
  border-radius:8px; transition:var(--t);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   CERTIFICATE VERIFY
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.cert-section {
  background:linear-gradient(135deg,#060f2a,#1a237e);
  position:relative; overflow:hidden;
}
.cert-section::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 60% 60% at 70% 50%,rgba(245,124,0,.15) 0%,transparent 70%);
}
.cert-glass {
  background:rgba(255,255,255,.07); backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.13); border-radius:var(--radius-xl); padding:2.8rem;
}
.cert-glass .form-control {
  background:rgba(255,255,255,.09); border:1px solid rgba(255,255,255,.18);
  color:#fff; border-radius:10px 0 0 10px; padding:.9rem 1.2rem;
}
.cert-glass .form-control::placeholder { color:rgba(255,255,255,.38); }
.cert-glass .form-control:focus { background:rgba(255,255,255,.13); border-color:var(--orange); box-shadow:none; color:#fff; }
.cert-ok {
  background:rgba(46,125,50,.15); border:1px solid rgba(46,125,50,.35);
  border-radius:var(--radius); padding:1.5rem; color:#fff; margin-top:1.5rem;
}
.cert-ok .cr { display:flex; gap:8px; margin-bottom:.4rem; font-size:.88rem; }
.cert-ok .cr .cl { opacity:.58; min-width:130px; }
.cert-fail {
  background:rgba(198,40,40,.15); border:1px solid rgba(198,40,40,.3);
  border-radius:var(--radius); padding:1.2rem 1.5rem; color:#fff; margin-top:1.5rem; font-size:.88rem;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FAQ
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.faq-section { background:#fff; }
.faq-item {
  background:var(--body-bg); border:1px solid var(--border);
  border-radius:var(--radius); margin-bottom:.8rem; overflow:hidden; transition:var(--t);
}
.faq-item.open { background:#fff; border-color:var(--blue); box-shadow:var(--shadow-sm); }
.faq-q {
  width:100%; background:none; border:none;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:1.1rem 1.4rem; text-align:left; cursor:pointer; transition:var(--t);
}
.faq-q .qtext { font-size:.93rem; font-weight:600; color:var(--dark); }
.faq-item.open .qtext { color:var(--blue); }
.faq-q .qicon {
  width:28px; height:28px; border-radius:8px; border:1.5px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  color:var(--text-muted); font-size:.75rem; flex-shrink:0; transition:var(--t);
}
.faq-item.open .qicon { background:var(--blue); border-color:var(--blue); color:#fff; transform:rotate(45deg); }
.faq-a {
  padding:0 1.4rem 1.1rem; font-size:.87rem; color:var(--text-soft); line-height:1.7; display:none;
}
.faq-item.open .faq-a { display:block; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   CTA SECTION
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.cta-section {
  background:linear-gradient(135deg,var(--orange) 0%,#bf360c 100%);
  position:relative; overflow:hidden;
}
.cta-section::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 50% 80% at 0% 50%,rgba(255,255,255,.1) 0%,transparent 70%);
}
.btn-cta-white {
  background:#fff; color:var(--orange)!important; font-weight:700;
  padding:.85rem 2.2rem; border-radius:10px; font-size:.97rem;
  transition:var(--t); box-shadow:0 6px 20px rgba(0,0,0,.15);
  display:inline-flex; align-items:center; gap:8px;
}
.btn-cta-white:hover { transform:translateY(-2px); box-shadow:0 10px 28px rgba(0,0,0,.2); }
.btn-cta-ghost {
  background:transparent; color:#fff!important; font-weight:700;
  padding:.85rem 2.2rem; border-radius:10px; font-size:.97rem;
  border:2px solid rgba(255,255,255,.5); transition:var(--t);
  display:inline-flex; align-items:center; gap:8px;
}
.btn-cta-ghost:hover { background:rgba(255,255,255,.15); border-color:#fff; transform:translateY(-2px); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FOOTER
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.site-footer { background:var(--dark); color:rgba(255,255,255,.68); }
.footer-top { padding:64px 0 40px; }
.footer-brand-name {
  font-family:'Poppins',sans-serif; font-size:1.25rem; font-weight:800; color:#fff;
  display:flex; align-items:center; gap:10px; margin-bottom:.8rem;
}
.footer-brand-name .fi {
  width:34px; height:34px; background:linear-gradient(135deg,var(--orange),#ff8f00);
  border-radius:9px; display:flex; align-items:center; justify-content:center;
  font-size:.9rem; color:#fff; flex-shrink:0;
}
.footer-brand p { font-size:.85rem; line-height:1.75; margin-bottom:1.2rem; }
.fci { display:flex; align-items:center; gap:9px; font-size:.83rem; margin-bottom:.55rem; }
.fci i { width:16px; color:var(--orange); font-size:.8rem; }
.footer-h { font-size:.75rem; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,.35); margin-bottom:1.1rem; }
.footer-links { list-style:none; padding:0; margin:0; }
.footer-links li { margin-bottom:.5rem; }
.footer-links a { font-size:.84rem; color:rgba(255,255,255,.58); display:flex; align-items:center; gap:7px; transition:var(--t); }
.footer-links a i { font-size:.6rem; color:var(--orange); }
.footer-links a:hover { color:#fff; padding-left:4px; }
.social-row { display:flex; gap:9px; margin-top:.5rem; }
.s-btn {
  width:38px; height:38px; border-radius:10px; border:1px solid rgba(255,255,255,.1);
  background:rgba(255,255,255,.07); color:rgba(255,255,255,.65);
  display:flex; align-items:center; justify-content:center; font-size:.88rem; transition:var(--t);
}
.s-btn:hover { background:var(--orange); color:#fff; border-color:var(--orange); transform:translateY(-2px); }
.footer-divider { border-color:rgba(255,255,255,.07); margin:0; }
.footer-bottom {
  padding:1.2rem 0; display:flex; align-items:center;
  justify-content:space-between; flex-wrap:wrap; gap:.5rem; font-size:.8rem;
}
.footer-bottom a { color:rgba(255,255,255,.45); font-size:.8rem; margin-left:1.2rem; transition:var(--t); }
.footer-bottom a:hover { color:var(--orange); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   FLOATING ELEMENTS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/* WhatsApp */
.wa-btn {
  position:fixed; bottom:88px; right:28px; z-index:1000;
  width:52px; height:52px; border-radius:50%;
  background:#25d366; color:#fff; border:none;
  display:flex; align-items:center; justify-content:center;
  font-size:1.5rem; box-shadow:0 6px 20px rgba(37,211,102,.45);
  cursor:pointer; transition:var(--t); text-decoration:none;
}
.wa-btn:hover { transform:scale(1.12) translateY(-2px); box-shadow:0 10px 28px rgba(37,211,102,.55); color:#fff; }
.wa-btn .wa-pulse {
  position:absolute; width:100%; height:100%; border-radius:50%;
  background:rgba(37,211,102,.4); animation:waPulse 2s ease-out infinite;
}
@keyframes waPulse { 0%{transform:scale(1);opacity:.8} 100%{transform:scale(1.8);opacity:0} }

/* Enquire side tab */
.enquire-tab {
  position:fixed; right:-1px; top:50%; transform:translateY(-50%);
  background:linear-gradient(180deg,var(--blue),var(--blue-dark));
  color:#fff; writing-mode:vertical-rl; text-orientation:mixed;
  padding:14px 10px; border-radius:10px 0 0 10px;
  font-size:.75rem; font-weight:700; letter-spacing:2px; text-transform:uppercase;
  cursor:pointer; z-index:999; transition:var(--t);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  box-shadow:-4px 0 16px rgba(0,0,0,.15);
}
.enquire-tab:hover { padding-right:14px; background:linear-gradient(180deg,var(--orange),var(--orange-dark)); }
.enquire-tab i { font-size:1rem; writing-mode:horizontal-tb; }

/* Scroll to top */
#scrollTop {
  position:fixed; bottom:28px; right:28px; z-index:1000;
  width:46px; height:46px; border-radius:12px; border:none;
  background:var(--blue); color:#fff;
  display:none; align-items:center; justify-content:center;
  font-size:1rem; box-shadow:var(--shadow); cursor:pointer; transition:var(--t);
}
#scrollTop.visible { display:flex; }
#scrollTop:hover { background:var(--blue-dark); transform:translateY(-3px); }

/* Flash message */
.flash-alert { border:none; border-radius:0; border-left:4px solid currentColor; font-size:.88rem; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LMS / STUDENT PORTAL
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.lms-banner {
  background:linear-gradient(135deg,var(--blue-dark),var(--blue-mid));
  color:#fff; padding:2rem 0; margin-bottom:0;
}
.lms-banner h4 { font-weight:800; margin-bottom:.2rem; }
.lms-banner p  { opacity:.72; font-size:.87rem; margin:0; }
.dash-stat {
  background:#fff; border-radius:var(--radius-lg); padding:1.6rem;
  border:1px solid var(--border); transition:var(--t); text-align:center;
}
.dash-stat:hover { box-shadow:var(--shadow); transform:translateY(-2px); }
.ds-icon { width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:1.3rem; margin:0 auto .8rem; }
.ds-val  { font-size:1.9rem; font-weight:800; line-height:1; margin-bottom:.25rem; }
.ds-lbl  { font-size:.74rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:.4px; }
.quick-action {
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:1.8rem 1.4rem; text-align:center; transition:var(--t);
  text-decoration:none; color:var(--text); display:block; height:100%;
}
.quick-action:hover { box-shadow:var(--shadow); transform:translateY(-4px); color:var(--text); }
.qa-icon { width:58px; height:58px; border-radius:16px; display:flex; align-items:center; justify-content:center; font-size:1.4rem; margin:0 auto .9rem; transition:var(--t); }
.quick-action:hover .qa-icon { transform:scale(1.1); }
.quick-action h6 { font-weight:700; margin-bottom:.25rem; }
.quick-action p  { font-size:.8rem; color:var(--text-muted); margin:0; }
.progress { border-radius:50px; overflow:hidden; }
.progress-bar { background:linear-gradient(90deg,var(--blue),var(--orange)); border-radius:50px; }

/* Lesson list */
.lesson-li { display:flex; align-items:center; justify-content:space-between; padding:.9rem 1.2rem; border-bottom:1px solid var(--border); transition:var(--t); }
.lesson-li:last-child { border-bottom:none; }
.lesson-li:hover { background:var(--blue-xlight); }
.lesson-num { width:30px; height:30px; border-radius:8px; background:var(--blue-light); color:var(--blue); display:flex; align-items:center; justify-content:center; font-size:.73rem; font-weight:700; flex-shrink:0; }
.lesson-li.watched .lesson-num { background:#dcfce7; color:var(--green); }

/* Exam options */
.option-label { cursor:pointer; border:2px solid var(--border)!important; border-radius:10px!important; padding:.9rem 1rem!important; transition:var(--t); display:flex; align-items:center; gap:10px; }
.option-label:hover { border-color:var(--blue)!important; background:var(--blue-xlight)!important; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   ADMIN PANEL
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.table thead th { background:var(--dark); color:#fff; border:none; font-size:.78rem; font-weight:600; letter-spacing:.4px; padding:.9rem 1rem; }
.table tbody td { padding:.82rem 1rem; vertical-align:middle; font-size:.85rem; }
.table-hover tbody tr:hover { background:var(--blue-xlight); }
.stat-card { border:none; border-radius:var(--radius-lg); box-shadow:var(--shadow-xs); }
.stat-card .stat-icon { width:46px; height:46px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.2rem; }
.card { border-radius:var(--radius); border-color:var(--border); }
.card-header { border-color:var(--border); }
.btn { border-radius:8px; font-weight:600; }
.btn-primary { background:var(--blue); border-color:var(--blue); }
.btn-primary:hover { background:var(--blue-dark); border-color:var(--blue-dark); }
.btn-outline-primary { color:var(--blue); border-color:var(--blue); }
.btn-outline-primary:hover { background:var(--blue); }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SCROLL ANIMATIONS
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.fade-up { opacity:0; transform:translateY(28px); transition:opacity .6s ease,transform .6s ease; }
.fade-up.visible { opacity:1; transform:translateY(0); }
.fade-left  { opacity:0; transform:translateX(-28px); transition:opacity .6s ease,transform .6s ease; }
.fade-left.visible { opacity:1; transform:translateX(0); }
.fade-right { opacity:0; transform:translateX(28px); transition:opacity .6s ease,transform .6s ease; }
.fade-right.visible { opacity:1; transform:translateX(0); }
.stagger > *:nth-child(1){transition-delay:.05s}
.stagger > *:nth-child(2){transition-delay:.13s}
.stagger > *:nth-child(3){transition-delay:.21s}
.stagger > *:nth-child(4){transition-delay:.29s}
.stagger > *:nth-child(5){transition-delay:.37s}
.stagger > *:nth-child(6){transition-delay:.45s}
.stagger > *:nth-child(7){transition-delay:.53s}
.stagger > *:nth-child(8){transition-delay:.61s}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   RESPONSIVE
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media (max-width:991px) {
  .hero-inner   { padding:80px 0 44px; }
  .hero-visual  { display:none; }
  .stat-sep     { display:none; }
  .hstats-sep   { display:none; }
  .section-pad  { padding:56px 0; }
  .enquire-tab  { display:none; }
}
@media (max-width:767px) {
  .hero-title       { font-size:2rem; }
  .utility-bar      { display:none; }
  .footer-top       { padding:40px 0 24px; }
  .footer-bottom    { flex-direction:column; text-align:center; }
  .footer-bottom a  { margin:0 .5rem; }
  .testi-card       { min-width:270px; }
  .step-connector   { display:none; }
}
@media (max-width:480px) {
  .announce-bar .tick-item { font-size:.72rem; padding:0 1.5rem; }
  .wa-btn  { bottom:78px; right:16px; }
  #scrollTop { bottom:18px; right:16px; }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LANDING v2 — NEW COMPONENT CLASSES
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* CSS variable added for section backgrounds */
:root { --bg-light: var(--body-bg); }

/* ── Section headings ──────────────────────────────────── */
.section-label {
  display:inline-block; font-size:.72rem; font-weight:700;
  letter-spacing:2px; text-transform:uppercase;
  color:var(--orange); margin-bottom:.6rem;
}
.section-title {
  font-size:clamp(1.6rem,3vw,2.3rem); font-weight:800;
  color:var(--dark); line-height:1.2; margin-bottom:.6rem;
}
.section-sub {
  color:var(--text-soft); font-size:.95rem; line-height:1.7;
  max-width:580px;
}
.text-center .section-sub { margin:0 auto; }

/* ── Navbar btn-login alias ────────────────────────────── */
.btn-login {
  background:linear-gradient(135deg,var(--orange),#ff8f00)!important;
  color:#fff!important; border-radius:8px; font-weight:700!important;
  padding:.45rem 1.2rem!important;
  box-shadow:0 4px 12px rgba(245,124,0,.4); transition:var(--t)!important;
}
.btn-login:hover { transform:translateY(-1px); box-shadow:0 6px 18px rgba(245,124,0,.5)!important; background:rgba(0,0,0,0)!important; background:linear-gradient(135deg,var(--orange-dark),var(--orange))!important; color:#fff!important; }

/* ── Student badge (navbar) ────────────────────────────── */
.student-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.15);
  border-radius:50px; padding:4px 14px 4px 5px; color:#fff;
}
.student-badge .avatar {
  width:28px; height:28px; background:linear-gradient(135deg,var(--orange),#ff8f00);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:.75rem; font-weight:700;
}
.student-badge span { font-size:.82rem; font-weight:600; }

/* ── Hero new classes ──────────────────────────────────── */
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.9); font-size:.74rem; font-weight:700;
  letter-spacing:2px; text-transform:uppercase;
  padding:6px 16px; border-radius:50px; margin-bottom:1.2rem;
}
.hero-gradient-text {
  background:linear-gradient(90deg,#ffd54f,#ff8f00);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.hero-sub { font-size:.97rem; color:rgba(255,255,255,.72); max-width:520px; line-height:1.75; }
.btn-hero-outline {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.1); color:#fff; border:2px solid rgba(255,255,255,.28);
  padding:.85rem 2rem; border-radius:10px; font-weight:600; font-size:.97rem;
  transition:var(--t); backdrop-filter:blur(4px);
}
.btn-hero-outline:hover { background:rgba(255,255,255,.18); border-color:rgba(255,255,255,.5); transform:translateY(-2px); color:#fff; }

.hero-trust { display:flex; flex-wrap:wrap; gap:.7rem 1.4rem; margin-top:1.6rem; }
.trust-item { display:flex; align-items:center; gap:7px; color:rgba(255,255,255,.78); font-size:.8rem; font-weight:500; }
.trust-item i { color:#69f0ae; font-size:.85rem; }

.hero-cards-cluster {
  display:grid; grid-template-columns:1fr 1fr; gap:16px;
}
.hcard-icon {
  width:44px; height:44px; border-radius:12px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:1.15rem; color:#fff;
}
.hcard { display:flex; align-items:center; gap:14px; }
.hcard-wide { grid-column: span 2; }
.hcard-title { font-size:.92rem; font-weight:700; color:#fff; }
.hcard-sub   { font-size:.72rem; color:rgba(255,255,255,.55); }

/* Hero stats bar (new layout) */
.hero-statsbar {
  position:relative; z-index:2; display:flex; align-items:center;
  flex-wrap:wrap; justify-content:center; gap:0;
  background:rgba(255,255,255,.06); border-top:1px solid rgba(255,255,255,.09);
  padding:1rem 0; margin-top:2.5rem;
  border-radius:var(--radius-lg);
}
.stat-pill { text-align:center; padding:.6rem 2rem; }
.stat-pill .stat-num {
  font-size:1.7rem; font-weight:900; display:block; line-height:1;
  background:linear-gradient(90deg,#ffd54f,#ff8f00);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.stat-lbl { font-size:.68rem; color:rgba(255,255,255,.5); text-transform:uppercase; letter-spacing:1px; margin-top:.25rem; display:block; }
.stat-divider { width:1px; height:40px; background:rgba(255,255,255,.1); }

/* ── Why Choose Us ─────────────────────────────────────── */
.why-section { background:var(--bg-light); }
.why-card {
  display:flex; align-items:flex-start; gap:14px;
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:1.2rem 1.4rem; transition:var(--t); height:100%;
}
.why-card:hover { box-shadow:var(--shadow); transform:translateY(-3px); }
.why-icon {
  width:44px; height:44px; border-radius:12px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:1.1rem;
}
.why-title { font-size:.88rem; font-weight:700; color:var(--dark); margin-bottom:.2rem; }
.why-desc  { font-size:.78rem; color:var(--text-muted); line-height:1.55; }
.btn-primary-soft {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--orange); color:#fff; font-weight:700; font-size:.9rem;
  padding:.75rem 1.6rem; border-radius:10px; transition:var(--t);
  box-shadow:0 4px 16px rgba(245,124,0,.35);
}
.btn-primary-soft:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(245,124,0,.45); color:#fff; }

/* ── Step card extras ──────────────────────────────────── */
.step-icon {
  width:64px; height:64px; border-radius:var(--radius);
  background:linear-gradient(135deg,rgba(245,124,0,.12),rgba(245,124,0,.05));
  color:var(--orange); display:flex; align-items:center; justify-content:center;
  font-size:1.6rem; margin:0 auto 1.2rem;
}
.step-title { font-size:1.05rem; font-weight:700; color:var(--dark); margin-bottom:.5rem; }
.step-desc  { font-size:.86rem; color:var(--text-soft); margin:0; line-height:1.65; }

/* ── Course cards (new design) ─────────────────────────── */
.course-card {
  background:#fff; border-radius:var(--radius-xl); overflow:hidden;
  box-shadow:var(--shadow); transition:var(--t); height:100%; position:relative;
  border-top:4px solid var(--cc-color, var(--orange));
}
.course-card:hover { transform:translateY(-8px); box-shadow:var(--shadow-xl); }
.course-popular-badge {
  position:absolute; top:16px; right:16px;
  background:linear-gradient(135deg,var(--orange),#ff8f00);
  color:#fff; font-size:.68rem; font-weight:800;
  padding:4px 14px; border-radius:50px; letter-spacing:.5px; text-transform:uppercase;
}
.cc-header { display:flex; align-items:center; gap:16px; padding:1.8rem 1.8rem 1.2rem; }
.cc-icon {
  width:56px; height:56px; border-radius:14px; flex-shrink:0;
  background:var(--cc-color, var(--orange));
  display:flex; align-items:center; justify-content:center; font-size:1.4rem; color:#fff;
  box-shadow:0 6px 16px color-mix(in srgb, var(--cc-color, var(--orange)) 40%, transparent);
}
.cc-name    { font-size:1.2rem; font-weight:800; color:var(--dark); margin:0; }
.cc-tagline { font-size:.78rem; color:var(--text-muted); margin:0; }
.cc-price   { display:flex; align-items:baseline; gap:4px; padding:0 1.8rem .5rem; }
.cc-amount  { font-size:2rem; font-weight:900; color:var(--cc-color, var(--orange)); }
.cc-period  { font-size:.8rem; color:var(--text-muted); }
.cc-duration {
  margin:0 1.8rem .8rem; padding:.5rem .8rem; border-radius:8px;
  background:var(--body-bg); font-size:.78rem; color:var(--text-muted); display:inline-block;
}
.cc-features {
  list-style:none; padding:.5rem 1.8rem 1.4rem; margin:0;
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
}
.cc-features li {
  display:flex; align-items:center; gap:10px;
  font-size:.85rem; color:var(--text); padding:.5rem 0;
  border-bottom:1px dashed var(--border);
}
.cc-features li:last-child { border-bottom:none; }
.cc-features li i { color:var(--cc-color, var(--orange)); font-size:.8rem; flex-shrink:0; }
.cc-btn {
  display:flex; align-items:center; justify-content:center; gap:8px;
  margin:1.4rem 1.8rem; padding:.85rem;
  background:var(--cc-color, var(--orange)); color:#fff;
  border-radius:10px; font-weight:700; font-size:.92rem;
  transition:var(--t); box-shadow:0 4px 16px color-mix(in srgb, var(--cc-color, var(--orange)) 40%, transparent);
}
.cc-btn:hover { color:#fff; filter:brightness(1.1); transform:translateY(-2px); }

/* ── Stats section (new) ───────────────────────────────── */
.stats-section { padding:3.5rem 0; }
.stats-num {
  font-size:clamp(2rem,5vw,3rem); font-weight:900; line-height:1; display:block;
  background:linear-gradient(90deg,#ffd54f,#ff8f00);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  margin-bottom:.4rem;
}
.stats-lbl { font-size:.75rem; color:rgba(255,255,255,.55); text-transform:uppercase; letter-spacing:1.5px; font-weight:500; }

/* ── Testimonial extras ────────────────────────────────── */
.testi-avatar {
  width:44px; height:44px; border-radius:50%; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-size:.9rem; font-weight:700; color:#fff;
  background:linear-gradient(135deg,var(--orange),#ff8f00);
}
.testi-hint { font-size:.75rem; color:var(--text-muted); }
.testi-scroll.grabbing { cursor:grabbing; }

/* ── Placement card extras ─────────────────────────────── */
.plc-avatar {
  width:64px; height:64px; border-radius:50%; margin:0 auto 1rem;
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; font-weight:800;
}
.plc-name  { font-size:.95rem; font-weight:700; color:var(--dark); margin-bottom:.2rem; }
.plc-role  { font-size:.82rem; color:var(--text-soft); margin-bottom:.3rem; }
.plc-org   { font-size:.78rem; color:var(--text-muted); margin-bottom:.7rem; }
.plc-badge {
  display:inline-block; font-size:.7rem; font-weight:700;
  background:var(--blue-light); color:var(--blue);
  padding:3px 12px; border-radius:50px;
}

/* ── Listing card (new) ────────────────────────────────── */
.listing-card {
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:1rem 1.2rem; margin-bottom:.75rem; transition:var(--t);
  height:auto; overflow:visible;
}
.listing-card:hover { box-shadow:var(--shadow-sm); transform:translateX(4px); }
.lc-left  { display:flex; align-items:center; gap:12px; flex:1; min-width:0; }
.lc-icon  { width:40px; height:40px; border-radius:10px; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:1rem; }
.lc-title { font-size:.9rem; font-weight:700; color:var(--dark); }
.lc-meta  { display:flex; flex-wrap:wrap; gap:.5rem .8rem; margin-top:.2rem; }
.lc-meta span { font-size:.73rem; color:var(--text-muted); display:flex; align-items:center; gap:3px; }
.lc-badge { font-size:.72rem; font-weight:700; padding:4px 12px; border-radius:50px; white-space:nowrap; flex-shrink:0; }
.listing-empty { text-align:center; padding:2.5rem 1rem; color:var(--text-muted); }
.listing-empty i { font-size:2.5rem; margin-bottom:.8rem; display:block; opacity:.35; }
.listing-empty p { font-size:.87rem; margin:0; }

/* ── Job tabs ───────────────────────────────────────────── */
.job-tabs { display:flex; gap:.4rem; }
.jtab {
  display:inline-flex; align-items:center; gap:5px;
  padding:.38rem .9rem; border-radius:50px; border:1.5px solid var(--border);
  background:#fff; color:var(--text-soft); font-size:.8rem; font-weight:600;
  cursor:pointer; transition:var(--t);
}
.jtab:hover { border-color:#f57c00; color:#f57c00; }
.jtab.active { background:#f57c00; border-color:#f57c00; color:#fff; }
.jtab-count {
  background:rgba(255,255,255,.25); color:inherit;
  font-size:.68rem; font-weight:700; padding:1px 6px; border-radius:10px;
}
.jtab:not(.active) .jtab-count { background:#f57c0022; color:#f57c00; }
.lc-view-all {
  display:inline-flex; align-items:center; gap:5px;
  font-size:.8rem; font-weight:600; color:#f57c00; text-decoration:none;
  margin-top:.3rem; transition:var(--t);
}
.lc-view-all:hover { gap:8px; }

/* ── Certificate glass (new form layout) ───────────────── */
.cg-header {
  display:flex; align-items:center; gap:10px;
  font-size:1.1rem; font-weight:700; color:#fff;
  margin-bottom:1.5rem;
}
.cg-header i { color:var(--orange); }
.cg-label { display:block; font-size:.78rem; font-weight:600; color:rgba(255,255,255,.6); margin-bottom:.5rem; letter-spacing:.5px; text-transform:uppercase; }
.cg-input-wrap { position:relative; margin-bottom:1rem; }
.cg-icon { position:absolute; left:14px; top:50%; transform:translateY(-50%); color:rgba(255,255,255,.4); font-size:.85rem; }
.cg-input {
  width:100%; padding:.85rem 1rem .85rem 2.8rem;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.18);
  border-radius:10px; color:#fff; font-size:.9rem; transition:var(--t);
}
.cg-input::placeholder { color:rgba(255,255,255,.35); }
.cg-input:focus { outline:none; border-color:var(--orange); background:rgba(255,255,255,.12); }
.cg-btn {
  width:100%; padding:.9rem; border-radius:10px; border:none;
  background:linear-gradient(135deg,var(--orange),#ff8f00); color:#fff;
  font-weight:700; font-size:.95rem; cursor:pointer; transition:var(--t);
  display:flex; align-items:center; justify-content:center; gap:8px;
}
.cg-btn:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(245,124,0,.45); }
.verify-trust-list { list-style:none; padding:0; margin:0; }
.verify-trust-list li { display:flex; align-items:center; gap:10px; font-size:.87rem; color:var(--text-soft); padding:.35rem 0; }
.verify-trust-list li i { color:var(--green); }

/* ── FAQ (new names) ───────────────────────────────────── */
.faq-wrap { max-width:780px; margin:0 auto; }
.faq-item { background:#fff; border:1px solid var(--border); border-radius:var(--radius); margin-bottom:.75rem; overflow:hidden; transition:var(--t); }
.faq-item.active { border-color:var(--orange); box-shadow:0 4px 16px rgba(245,124,0,.12); }
.faq-q { width:100%; display:flex; align-items:center; justify-content:space-between; gap:1rem; padding:1.1rem 1.4rem; background:none; border:none; text-align:left; cursor:pointer; transition:var(--t); }
.faq-q span { font-size:.93rem; font-weight:600; color:var(--dark); }
.faq-item.active .faq-q span { color:var(--orange); }
.faq-chevron { color:var(--text-muted); font-size:.8rem; transition:transform .3s ease; flex-shrink:0; }
.faq-chevron.rotated { transform:rotate(-180deg); color:var(--orange); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .4s ease, padding .3s ease; padding:0 1.4rem; }
.faq-a.open { max-height:300px; padding-bottom:1.2rem; }
.faq-a p { font-size:.87rem; color:var(--text-soft); line-height:1.7; margin:0; }

/* ── CTA section extras ────────────────────────────────── */
.cta-section { padding:5rem 0; }
.cta-badge {
  display:inline-block; background:rgba(255,255,255,.2); color:#fff;
  font-size:.72rem; font-weight:700; letter-spacing:1.5px; text-transform:uppercase;
  padding:5px 18px; border-radius:50px; margin-bottom:1rem;
}
.cta-title { font-size:clamp(1.8rem,4vw,2.8rem); font-weight:900; color:#fff; margin-bottom:.8rem; }
.cta-sub   { color:rgba(255,255,255,.8); font-size:.97rem; line-height:1.7; margin-bottom:0; }
.cta-shapes { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.cta-shape { position:absolute; border-radius:50%; filter:blur(60px); opacity:.15; }
.cs1 { width:400px; height:400px; background:#fff; top:-100px; left:-100px; }
.cs2 { width:300px; height:300px; background:#fff; bottom:-80px; right:-80px; }

/* ── Svc card title/desc ───────────────────────────────── */
.svc-title { font-size:.97rem; font-weight:700; color:var(--dark); margin-bottom:.4rem; }
.svc-desc  { font-size:.83rem; color:var(--text-muted); margin:0; line-height:1.6; }

/* ── Stagger direct children ───────────────────────────── */
.stagger { opacity:0; transform:translateY(20px); transition:opacity .5s ease,transform .5s ease; }
.stagger.visible { opacity:1; transform:translateY(0); }

@media (max-width:767px) {
  .stat-divider { display:none; }
  .hero-cards-cluster { grid-template-columns:1fr; }
  .hcard-wide { grid-column:span 1; }
  .faq-wrap { max-width:100%; }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PAGE HERO (inner pages banner)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.page-hero {
  background:linear-gradient(135deg,#050e2d 0%,#0d3c7a 55%,#1a237e 100%);
  padding:4.5rem 0 3.5rem; position:relative; overflow:hidden;
}
.page-hero::before {
  content:''; position:absolute; inset:0; opacity:.04;
  background-image:linear-gradient(rgba(255,255,255,.5) 1px,transparent 1px),
                   linear-gradient(90deg,rgba(255,255,255,.5) 1px,transparent 1px);
  background-size:40px 40px;
}
.ph-shapes { position:absolute; inset:0; pointer-events:none; }
.phs { position:absolute; border-radius:50%; filter:blur(70px); opacity:.18; }
.phs1 { width:400px;height:400px;background:#3b82f6; top:-120px;right:-80px; }
.phs2 { width:280px;height:280px;background:var(--orange); bottom:-60px;left:-60px; }
.ph-breadcrumb {
  display:inline-flex; align-items:center; gap:8px;
  font-size:.75rem; color:rgba(255,255,255,.55); margin-bottom:.8rem;
}
.ph-breadcrumb a { color:rgba(255,255,255,.55); }
.ph-breadcrumb a:hover { color:#fff; }
.ph-breadcrumb i { font-size:.55rem; }
.ph-title {
  font-size:clamp(1.8rem,4vw,3rem); font-weight:900; color:#fff;
  margin-bottom:.6rem;
}
.ph-sub {
  color:rgba(255,255,255,.68); font-size:.97rem; max-width:540px; margin:0 auto;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SERVICES PAGE
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.svc-stat-pill {
  display:flex; flex-direction:column; align-items:center; gap:4px;
  padding:.8rem; border-radius:var(--radius); background:#fff;
  border:1px solid var(--border);
}
.svc-stat-pill i  { font-size:1.4rem; }
.svc-stat-pill strong { font-size:1.1rem; font-weight:800; color:var(--dark); }
.svc-stat-pill span   { font-size:.73rem; color:var(--text-muted); }

.svc-detail-icon {
  width:64px; height:64px; border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.6rem; margin-bottom:1rem;
}
.svc-feature-list { list-style:none; padding:0; margin:0; }
.svc-feature-list li {
  display:flex; align-items:center; gap:10px;
  font-size:.88rem; color:var(--text-soft); padding:.4rem 0;
}
.svc-feature-list li i { color:var(--green); font-size:.85rem; flex-shrink:0; }

.svc-price-table { border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.spt-row {
  display:flex; justify-content:space-between; align-items:center;
  padding:.7rem 1.1rem; border-bottom:1px solid var(--border); font-size:.87rem;
}
.spt-row:last-child { border-bottom:none; }
.spt-row span:last-child { font-weight:700; color:var(--orange); }
.spt-row:nth-child(even) { background:var(--bg-light); }

.svc-highlight-box {
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg);
  overflow:hidden; border-top:4px solid var(--sh-color, var(--orange));
  padding:2rem;
}
.sh-header {
  font-size:.97rem; font-weight:700; color:var(--dark); margin-bottom:1.2rem;
}
.sh-icon {
  width:56px; height:56px; border-radius:14px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem; margin-bottom:1rem;
}
.sh-title { font-size:1.15rem; font-weight:800; color:var(--dark); margin-bottom:.4rem; }
.sh-desc  { font-size:.87rem; color:var(--text-soft); margin-bottom:1rem; }
.sh-list  { list-style:none; padding:0; margin:0 0 1.4rem; }
.sh-list li { display:flex; align-items:center; gap:9px; font-size:.86rem; color:var(--text); padding:.3rem 0; }
.sh-list li i { color:var(--green); font-size:.8rem; flex-shrink:0; }
.sh-btn {
  display:inline-flex; align-items:center; gap:8px;
  background:var(--sh-color, var(--orange)); color:#fff;
  font-weight:700; font-size:.88rem; padding:.65rem 1.4rem;
  border-radius:9px; transition:var(--t);
}
.sh-btn:hover { color:#fff; filter:brightness(1.1); transform:translateY(-1px); }

.repair-chip {
  display:flex; align-items:center; gap:8px;
  background:#fff; border:1px solid var(--border); border-radius:8px;
  padding:.55rem .9rem; font-size:.82rem; font-weight:600; color:var(--text);
  transition:var(--t);
}
.repair-chip:hover { border-color:var(--orange); color:var(--orange); }
.repair-chip i { color:var(--orange); font-size:.8rem; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   ABOUT PAGE
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.about-stats-row { display:flex; gap:1.5rem; flex-wrap:wrap; }
.asr-item { text-align:center; }
.asr-num {
  font-size:2rem; font-weight:900; display:block; line-height:1;
  color:var(--orange);
}
.asr-lbl { font-size:.72rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:1px; }

.about-visual {
  position:relative; min-height:320px;
  display:flex; align-items:center; justify-content:center;
}
.av-main {
  background:linear-gradient(135deg,#050e2d,#0d3c7a);
  border-radius:var(--radius-xl); padding:3rem 2.5rem;
  text-align:center; color:#fff; width:100%;
}
.av-main i   { font-size:3.5rem; color:var(--orange); margin-bottom:1rem; display:block; }
.av-main span{ font-size:1.3rem; font-weight:800; display:block; margin-bottom:.4rem; }
.av-main p   { color:rgba(255,255,255,.6); font-size:.87rem; margin:0; }
.av-badge {
  position:absolute; background:#fff; border-radius:50px;
  padding:.5rem 1.2rem; font-size:.78rem; font-weight:700; color:var(--dark);
  box-shadow:var(--shadow); display:flex; align-items:center; gap:7px; white-space:nowrap;
}
.av-badge i  { color:var(--orange); }
.av-b1 { top:10px; right:-10px; }
.av-b2 { bottom:50px; left:-10px; }
.av-b3 { bottom:10px; right:10px; }

.mv-card {
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:2rem 1.8rem; height:100%; border-top:4px solid var(--mv-color, var(--orange));
  transition:var(--t);
}
.mv-card:hover { box-shadow:var(--shadow); transform:translateY(-4px); }
.mv-icon {
  width:52px; height:52px; border-radius:14px;
  background:var(--mv-color, var(--orange)); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; margin-bottom:1rem;
}
.mv-title { font-size:1.05rem; font-weight:800; color:var(--dark); margin-bottom:.5rem; }
.mv-desc  { font-size:.87rem; color:var(--text-soft); line-height:1.7; }

.facility-card {
  display:flex; align-items:center; gap:14px;
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:1.2rem 1.4rem; transition:var(--t);
}
.facility-card:hover { box-shadow:var(--shadow-sm); }
.fc-icon {
  width:48px; height:48px; border-radius:12px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center; font-size:1.2rem;
}
.fc-title { font-size:.9rem; font-weight:700; color:var(--dark); }
.fc-desc  { font-size:.78rem; color:var(--text-muted); }

/* Timeline */
.timeline { position:relative; max-width:800px; margin:0 auto; }
.timeline::before {
  content:''; position:absolute; left:50%; top:0; bottom:0;
  width:2px; background:linear-gradient(180deg,var(--orange),var(--blue));
  transform:translateX(-50%);
}
.tl-item {
  display:flex; width:50%; padding-bottom:2.5rem;
  position:relative;
}
.tl-left  { padding-right:2.5rem; justify-content:flex-end; }
.tl-right { padding-left:2.5rem; margin-left:50%; }
.tl-dot {
  position:absolute; width:14px; height:14px; border-radius:50%;
  top:8px; z-index:1;
}
.tl-left  .tl-dot { right:-7px; }
.tl-right .tl-dot { left:-7px; }
.tl-card {
  background:#fff; border:1px solid var(--border); border-radius:var(--radius);
  padding:1rem 1.2rem; max-width:280px; box-shadow:var(--shadow-xs);
}
.tl-year  { font-size:.8rem; font-weight:700; margin-bottom:.3rem; }
.tl-title { font-size:.92rem; font-weight:700; color:var(--dark); margin-bottom:.3rem; }
.tl-desc  { font-size:.8rem; color:var(--text-muted); line-height:1.6; }

@media (max-width:767px) {
  .timeline::before { left:16px; }
  .tl-item, .tl-left, .tl-right { width:100%; padding-left:40px; padding-right:0; margin-left:0; justify-content:flex-start; }
  .tl-dot { left:10px!important; right:auto!important; }
  .tl-card { max-width:100%; }
  .av-badge { display:none; }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   CONTACT PAGE
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.contact-card {
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:1.8rem 1.5rem; text-align:center; transition:var(--t); height:100%;
  border-top:4px solid var(--cc2-color, var(--orange));
}
.contact-card:hover { box-shadow:var(--shadow); transform:translateY(-4px); }
.cc2-icon {
  width:52px; height:52px; border-radius:14px;
  background:var(--cc2-color, var(--orange)); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; margin:0 auto .9rem;
}
.cc2-label { font-size:.72rem; text-transform:uppercase; letter-spacing:1px; color:var(--text-muted); margin-bottom:.4rem; }
.cc2-val   { font-size:.9rem; font-weight:600; color:var(--dark); line-height:1.5; }
.cc2-val a { color:var(--dark); }
.cc2-val a:hover { color:var(--orange); }

/* Contact form */
.contact-form { }
.cf-label { display:block; font-size:.78rem; font-weight:600; color:var(--text-soft); margin-bottom:.4rem; }
.cf-input-wrap { position:relative; }
.cf-ico { position:absolute; left:12px; top:50%; transform:translateY(-50%); color:var(--text-muted); font-size:.82rem; }
.cf-input {
  width:100%; padding:.78rem 1rem .78rem 2.5rem;
  border:1.5px solid var(--border); border-radius:var(--radius);
  font-size:.88rem; color:var(--text); background:#fff; transition:var(--t);
}
.cf-input:focus { outline:none; border-color:var(--orange); box-shadow:0 0 0 3px rgba(245,124,0,.1); }
.cf-select { appearance:none; cursor:pointer; }
.cf-textarea {
  width:100%; padding:.78rem 1rem;
  border:1.5px solid var(--border); border-radius:var(--radius);
  font-size:.88rem; color:var(--text); resize:vertical; min-height:140px;
  transition:var(--t);
}
.cf-textarea:focus { outline:none; border-color:var(--orange); box-shadow:0 0 0 3px rgba(245,124,0,.1); }
.cf-btn {
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg,var(--orange),#ff8f00); color:#fff;
  border:none; padding:.85rem 2.2rem; border-radius:10px;
  font-weight:700; font-size:.93rem; cursor:pointer; transition:var(--t);
  box-shadow:0 4px 16px rgba(245,124,0,.35);
}
.cf-btn:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(245,124,0,.45); }
.contact-success {
  display:flex; align-items:flex-start; gap:14px;
  background:#f0fdf4; border:1.5px solid #86efac; border-radius:var(--radius-lg);
  padding:1.5rem; color:var(--dark);
}
.contact-success i { color:var(--green); font-size:1.6rem; flex-shrink:0; margin-top:2px; }
.contact-success strong { display:block; margin-bottom:.3rem; }
.contact-success p { font-size:.86rem; color:var(--text-soft); margin:0; }

/* Map placeholder */
.map-placeholder {
  height:220px; background:linear-gradient(135deg,var(--body-bg),var(--blue-xlight));
  border:1.5px dashed var(--border-dark); border-radius:var(--radius-lg);
  display:flex; align-items:center; justify-content:center;
}
.mp-inner { text-align:center; color:var(--text-muted); }
.mp-inner i  { font-size:2.5rem; color:var(--orange); margin-bottom:.6rem; display:block; }
.mp-inner p  { font-weight:700; color:var(--text); margin-bottom:.2rem; font-size:.9rem; }
.mp-inner span { font-size:.8rem; }

/* Quick contact box */
.quick-contact-box {
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg);
  overflow:hidden;
}
.qcb-title {
  font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:1px;
  color:var(--text-muted); padding:.9rem 1.3rem; background:var(--bg-light);
  border-bottom:1px solid var(--border);
}
.qcb-option {
  display:flex; align-items:center; gap:12px; padding:1rem 1.3rem;
  border-bottom:1px solid var(--border); transition:var(--t); color:var(--text);
}
.qcb-option:last-child { border-bottom:none; }
.qcb-option:hover { background:var(--bg-light); color:var(--text); }
.qcb-icon {
  width:40px; height:40px; border-radius:10px; flex-shrink:0;
  background:var(--qcb-color, var(--orange)); color:#fff;
  display:flex; align-items:center; justify-content:center; font-size:1rem;
}
.qcb-label { font-size:.82rem; font-weight:700; color:var(--dark); }
.qcb-val   { font-size:.75rem; color:var(--text-muted); }
.qcb-arrow { color:var(--text-muted); font-size:.7rem; margin-left:auto; }

/* Social follow box */
.social-follow-box {
  background:#fff; border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:1.2rem 1.4rem;
}
.sfb-title { font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:1px; color:var(--text-muted); margin-bottom:.9rem; }
.sfb-links { display:flex; gap:.6rem; }
.sfb-btn {
  width:40px; height:40px; border-radius:10px; border:1px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  font-size:.9rem; transition:var(--t); color:var(--text-soft);
}
.sfb-fb:hover  { background:#1877f2; border-color:#1877f2; color:#fff; }
.sfb-ig:hover  { background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); border-color:#e6683c; color:#fff; }
.sfb-yt:hover  { background:#ff0000; border-color:#ff0000; color:#fff; }
.sfb-wa:hover  { background:#25d366; border-color:#25d366; color:#fff; }

/* ================================================================
   Public Portal Cards (Govt Jobs / Pvt Jobs / Scholarships / Results)
   ================================================================ */

/* Page hero stats bar */
.portal-stats {
  display: flex; gap: 1.2rem; justify-content: center; flex-wrap: wrap;
  margin-top: 1.2rem;
}
.portal-stats span {
  background: rgba(255,255,255,0.15);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,0.25);
  border-radius: 30px;
  padding: .35rem .9rem;
  font-size: .82rem;
  font-weight: 500;
  color: #fff;
  display: flex; align-items: center; gap: .45rem;
}

/* Portal card */
.portal-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 1.4rem;
  height: 100%;
  display: flex; flex-direction: column;
  transition: var(--t);
  border-top: 3px solid var(--pc-color, #1565c0);
}
.portal-card:hover {
  box-shadow: 0 8px 32px rgba(0,0,0,0.10);
  transform: translateY(-3px);
}
.pc-badge {
  display: inline-flex; align-items: center;
  font-size: .72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .8px;
  padding: .25rem .65rem;
  border-radius: 30px;
  margin-bottom: .75rem;
  width: fit-content;
}
.pc-title {
  font-size: 1.05rem; font-weight: 700;
  color: var(--text-main);
  margin-bottom: .6rem;
  line-height: 1.35;
}
.pc-meta {
  display: flex; flex-wrap: wrap; gap: .4rem;
  margin-bottom: .75rem;
}
.pc-meta span {
  display: inline-flex; align-items: center; gap: .35rem;
  font-size: .78rem; color: var(--text-soft);
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: .2rem .6rem;
}
.pc-meta span i { font-size: .7rem; opacity: .7; }
.pc-salary {
  font-size: .9rem; font-weight: 700;
  color: var(--pc-color, #1565c0);
  border: 1px solid currentColor;
  border-radius: 8px;
  padding: .3rem .7rem;
  display: inline-flex; align-items: center;
  margin-bottom: .75rem;
  width: fit-content;
  opacity: .85;
}
.pc-desc {
  font-size: .85rem; color: var(--text-soft);
  line-height: 1.6;
  flex: 1;
  margin-bottom: .75rem;
  display: -webkit-box; -webkit-line-clamp: 4;
  -webkit-box-orient: vertical; overflow: hidden;
}
.pc-footer {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: .5rem;
  margin-top: auto;
  padding-top: .75rem;
  border-top: 1px solid var(--border);
}
.pc-deadline {
  font-size: .78rem; color: #e53935; font-weight: 600;
  display: inline-flex; align-items: center; gap: .3rem;
}
.pc-btn {
  display: inline-flex; align-items: center; gap: .35rem;
  background: var(--pc-color, #1565c0);
  color: #fff;
  font-size: .78rem; font-weight: 600;
  padding: .4rem .9rem;
  border-radius: 8px;
  text-decoration: none;
  transition: var(--t);
}
.pc-btn:hover {
  filter: brightness(1.1);
  color: #fff;
  text-decoration: none;
}

/* Empty state */
.portal-empty {
  text-align: center;
  padding: 4rem 1rem;
  color: var(--text-soft);
}
.portal-empty i {
  font-size: 3.5rem;
  margin-bottom: 1rem;
  opacity: .35;
  display: block;
}
.portal-empty h4 {
  font-size: 1.2rem; font-weight: 700;
  color: var(--text-main);
  margin-bottom: .5rem;
}
.portal-empty p {
  max-width: 380px; margin: 0 auto 1rem;
  font-size: .9rem;
}

/* Admin table small buttons */
.btn-xs {
  padding: .2rem .45rem;
  font-size: .75rem;
  border-radius: 6px;
  line-height: 1.4;
}

/* ================================================================
   Local Jobs Card
   ================================================================ */

.lj-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 1.4rem;
  height: 100%;
  display: flex; flex-direction: column;
  transition: var(--t);
  border-top: 3px solid #e65100;
  position: relative;
}
.lj-card:hover {
  box-shadow: 0 8px 32px rgba(0,0,0,0.10);
  transform: translateY(-3px);
}
.lj-urgent {
  border-top-color: #d32f2f;
  box-shadow: 0 0 0 1px rgba(211,47,47,0.15);
}

/* Labels */
.lj-labels {
  display: flex; flex-wrap: wrap; gap: .4rem;
  margin-bottom: .75rem;
}
.lj-label {
  display: inline-flex; align-items: center; gap: .3rem;
  font-size: .68rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .7px;
  padding: .22rem .6rem;
  border-radius: 30px;
  background: color-mix(in srgb, var(--lbl-color) 12%, transparent);
  color: var(--lbl-color);
  border: 1px solid color-mix(in srgb, var(--lbl-color) 30%, transparent);
}

/* Title */
.lj-title {
  font-size: 1.08rem; font-weight: 700;
  color: var(--text-main);
  margin-bottom: .7rem;
  line-height: 1.35;
}

/* Chips row */
.lj-chips {
  display: flex; flex-wrap: wrap; gap: .4rem;
  margin-bottom: .8rem;
}
.lj-chip {
  display: inline-flex; align-items: center; gap: .35rem;
  font-size: .78rem; font-weight: 500;
  padding: .28rem .7rem;
  border-radius: 20px;
  border: 1px solid var(--border);
}
.lj-chip i { font-size: .7rem; }
.lj-chip-place  { background: #fff3e0; color: #e65100; border-color: #ffcc80; }
.lj-chip-salary { background: #e8f5e9; color: #2e7d32; border-color: #a5d6a7; }
.lj-chip-time   { background: #e3f2fd; color: #1565c0; border-color: #90caf9; }
.lj-chip-edu    { background: #f3e5f5; color: #6a1b9a; border-color: #ce93d8; }

/* Description */
.lj-desc {
  font-size: .85rem; color: var(--text-soft);
  line-height: 1.65;
  margin-bottom: .8rem;
  display: -webkit-box; -webkit-line-clamp: 4;
  -webkit-box-orient: vertical; overflow: hidden;
}

/* Extra services */
.lj-extras {
  font-size: .8rem; color: #2e7d32;
  background: #e8f5e9;
  border: 1px solid #a5d6a7;
  border-radius: 8px;
  padding: .45rem .75rem;
  margin-bottom: .85rem;
  line-height: 1.55;
}

/* Contact section */
.lj-contacts {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: .8rem 1rem;
  margin-bottom: .85rem;
}
.lj-contact-label {
  font-size: .72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .8px;
  color: var(--text-muted);
  margin-bottom: .6rem;
}
.lj-contact-row {
  display: flex; gap: 1.2rem; flex-wrap: wrap;
}
.lj-contact-person {
  display: flex; flex-direction: column; gap: .25rem;
  flex: 1; min-width: 130px;
}
.lj-cp-name {
  font-size: .85rem; font-weight: 700;
  color: var(--text-main);
  display: flex; flex-direction: column; gap: .1rem;
}
.lj-cp-role {
  font-size: .72rem; font-weight: 400;
  color: var(--text-muted);
  text-transform: capitalize;
}
.lj-cp-phone {
  display: inline-flex; align-items: center; gap: .35rem;
  font-size: .82rem; font-weight: 600;
  color: #2e7d32;
  text-decoration: none;
  transition: var(--t);
}
.lj-cp-phone:hover { color: #1b5e20; text-decoration: underline; }
.lj-cp-phone i { font-size: .75rem; }

/* Footer */
.lj-footer {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: .5rem;
  margin-top: auto;
  padding-top: .75rem;
  border-top: 1px solid var(--border);
}
.lj-posted-by {
  font-size: .73rem; color: var(--text-muted);
  display: inline-flex; align-items: center; gap: .3rem;
}
.lj-posted-by i { color: #2e7d32; }
.lj-deadline {
  font-size: .76rem; font-weight: 600; color: #e53935;
  display: inline-flex; align-items: center; gap: .3rem;
}

/* Dark mode fallback for color-mix (older browsers) */
@supports not (color: color-mix(in srgb, red 10%, transparent)) {
  .lj-label { background: rgba(0,0,0,0.07); }
}

/* ── Affiliations / Certifications Section ──────────────────── */
.affil-section {
  background: #f8fafc;
  padding: 2.5rem 0;
  border-top: 1px solid #e8edf2;
  border-bottom: 1px solid #e8edf2;
}
.affil-label {
  text-align: center;
  font-size: .72rem; text-transform: uppercase;
  letter-spacing: 1.8px; font-weight: 700;
  color: #94a3b8; margin-bottom: 1.5rem;
}
.affil-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem;
  max-width: 860px; margin: 0 auto;
}
.affil-card {
  display: flex; align-items: center; gap: 1rem;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  padding: 1.1rem 1.25rem;
  text-decoration: none;
  transition: box-shadow .2s, transform .2s, border-color .2s;
  position: relative;
}
a.affil-card:hover {
  box-shadow: 0 8px 24px rgba(0,0,0,.08);
  transform: translateY(-2px);
  border-color: #cbd5e1;
  cursor: pointer;
}
.affil-logo-wrap {
  width: 56px; height: 56px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.affil-logo-img {
  width: 56px; height: 56px;
  object-fit: contain;
  filter: drop-shadow(0 1px 3px rgba(0,0,0,.12));
}
.affil-logo-icon {
  width: 56px; height: 56px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
}
.affil-body { flex: 1; min-width: 0; }
.affil-title {
  font-size: .88rem; font-weight: 700;
  color: #1e293b; line-height: 1.3;
}
.affil-sub {
  font-size: .72rem; color: #64748b;
  margin-top: 2px; line-height: 1.3;
}
.affil-reg-chip {
  display: inline-flex; align-items: center; gap: 4px;
  margin-top: 6px;
  padding: 3px 8px;
  background: color-mix(in srgb, var(--chip-color) 10%, transparent);
  border: 1px solid color-mix(in srgb, var(--chip-color) 25%, transparent);
  border-radius: 20px;
  font-size: .68rem; font-weight: 600;
  color: color-mix(in srgb, var(--chip-color) 80%, #1e293b);
  font-family: 'Courier New', monospace;
  letter-spacing: .3px;
}
.affil-reg-chip i { font-size: .6rem; opacity: .7; }
.affil-verified {
  font-size: 1.1rem; flex-shrink: 0;
  opacity: .85;
}
@media (max-width: 480px) {
  .affil-grid { grid-template-columns: 1fr; }
}


/* ── Audience Features ───────────────────────────────────────────────── */
.btn-purple {
  background: #7c3aed; color: #fff; border: none;
}
.btn-purple:hover { background: #6d28d9; color: #fff; }
.btn-outline-purple {
  border: 2px solid #7c3aed; color: #7c3aed; background: transparent;
}
.btn-outline-purple:hover { background: #7c3aed; color: #fff; }
.text-purple { color: #7c3aed !important; }
.bg-purple { background: #7c3aed !important; }
.bg-purple-soft { background: #f5f0ff !important; }

.gallery-thumb {
  position: relative; padding-top: 75%; overflow: hidden;
  border-radius: 12px; cursor: pointer;
  box-shadow: 0 2px 12px rgba(0,0,0,.08);
  transition: .25s;
}
.gallery-thumb:hover { transform: translateY(-4px); box-shadow: 0 8px 28px rgba(124,58,237,.2); }
.gallery-thumb img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; transition: .35s;
}
.gallery-thumb:hover img { transform: scale(1.06); }
