:root {
  --sky-bright: #006db4;
  --sky-soft: #d6effb;
  --sky-deep: #006db4;
  --secondary: #7c859b;
  --sky-ink: #006db4;
  --darkblue: #006db4;
  --accent: #c82210;
  --accent-deep: #c82210;
  --ink: #04070c;
  --muted: #7c859b;
  --bg: #f7fbfe;
  --card: #ffffff;
  --gradient-primary: linear-gradient(135deg, #006db4 0%, #006db4 60%, #006db4 100%);
  --gradient-accent: linear-gradient(135deg, #c82210 0%, #c82210 100%);
  --shadow-elegant: 0 30px 80px -30px rgba(25, 170, 237, 0.45);
  --shadow-elegant-red: 0 30px 80px -30px #c822106e;
  --shadow-card: 0 10px 30px -14px rgba(15, 39, 72, 0.30);
  --radius: 16px;
  --gradient-hero: radial-gradient(ellipse 80% 60% at 80% 0%, #006db447, transparent 60%), radial-gradient(ellipse 60% 50% at 0% 100%, #006db45c, transparent 60%), linear-gradient(180deg, #006db436 0%, #e6f3fb 100%);
  --card-w: 340px;
  --gap: 24px;
  --shadow-card: 0 10px 30px -14px rgba(14, 42, 77, .25);
  --shadow-elegant: 0 30px 80px -30px rgba(25, 170, 237, .45);
}

.bg-blue {
  background: #1472b3 !important;
}

.bg-darkblue {
  background: var(--darkblue) !important;
}

.bg-red {
  background-color: var(--accent) !important;
}

.text-red {
  color: var(--accent) !important;
}

.text-sec {
  color: var(--secondary);
}

.text-blue {
  color: var(--darkblue) !important;
}

.lh-0 {
  line-height: 0;
}

.fs-18 {
  font-size: 18px !important;
}

.fs-17 {
  font-size: 17px !important;
}

.fs-16 {
  font-size: 16px !important;
}

.fs-15 {
  font-size: 15px !important;
}

.fs-14 {
  font-size: 14px !important;
}

.fs-13 {
  font-size: 13px !important;
}

.ltr-1 {
  letter-spacing: .5px;
}

.ltr-2 {
  letter-spacing: 1px;
}

.ltr-3 {
  letter-spacing: 1.5px;
}

.ltr-4 {
  letter-spacing: 2px;
}

/* Bootstrap brand override */
.btn-primary {
  --bs-btn-bg: var(--darkblue);
  --bs-btn-border-color: var(--darkblue);
  --bs-btn-hover-bg: var(--sky-deep);
  --bs-btn-hover-border-color: var(--sky-deep);
  --bs-btn-active-bg: var(--sky-deep);
  --bs-btn-active-border-color: var(--sky-deep);
}

.text-primary {
  color: var(--darkblue) !important;
}

.bg-primary {
  background-color: var(--darkblue) !important;
}

/* ===== Base ===== */
* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  color: var(--ink);
  background: var(--bg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

@font-face {
  font-family: 'Barlow';
  src: url('../font/ogilvy/ogilvyserif-bold.otf') format('opentype');
  font-display: swap;
}

/* Sans - Light */
@font-face {
  font-family: 'Ogilvy Sans';
  src: url('../font/ogilvy/ogilvysans-light.otf') format('opentype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}

/* Serif - Regular */
@font-face {
  font-family: 'Ogilvy Serif';
  src: url('../font/ogilvy/ogilvyserif-regular.otf') format('opentype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* Serif - Bold */
@font-face {
  font-family: 'Ogilvy Serif';
  src: url('../font/ogilvy/ogilvyserif-bold.otf') format('opentype');
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: 'HelveticaNeueLT';
  src: url('../font/helvetica/HelveticaNeueLT-BoldCond.otf') format('opentype');
  font-weight: bold;
  font-display: swap;
}

.Helvetica-font {
  font-family: 'HelveticaNeueLT';
  letter-spacing: .5px;
}

.ogilvyserif {
  font-family: 'Ogilvy Serif';
  letter-spacing: .5px;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: 'Ogilvy Serif', serif;
  font-weight: 700;
}

.fw-5 {
  font-weight: 500 !important;
}

h1 {
  font-weight: 900;
  letter-spacing: -0.025em;
}

a {
  color: var(--darkblue);
  text-decoration: none;
  transition: color .2s;
}

a:hover {
  color: var(--sky-deep);
}

.text-gradient {
  background: linear-gradient(135deg, var(--darkblue) 0%, var(--sky-deep) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  padding: 8px;
}

.text-muted-soft {
  color: var(--muted) !important;
}

.lang-select {
  padding: 8px 14px;
  border-radius: 25px;
  border: 1px solid #ddd;
  background: #f5f5f5;
  font-size: 14px;
  cursor: pointer;
}

/* header and all */
/* Hide the Google Translate Top Bar */
.goog-te-banner-frame.skiptranslate,
.goog-te-gadget-icon {
  display: none !important;
}

body {
  top: 0px !important;
}

/* Style the Google Gadget Container */
#google_translate_element {
  padding: 6px 10px !important;
  text-align: right;
}

/* Make the dropdown look like a Bootstrap element */
.goog-te-gadget-simple {
  background-color: #fff !important;
  border: 1px solid #dee2e6 !important;
  padding: 8px 16px !important;
  border-radius: 50px !important;
  font-family: 'Poppins', sans-serif !important;
  font-size: 14px !important;
  display: inline-block !important;
  cursor: pointer;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
}

.goog-te-menu-value span {
  color: #333 !important;
  font-weight: 500;
}

.VIpgJd-ZVi9od-ORHb-OEVmcd {
  display: none !important;
}

/* ends here */
/* Hide the Google Translate Top Bar */
.goog-te-banner-frame.skiptranslate,
.goog-te-gadget-icon {
  display: none !important;
}

body {
  top: 0px !important;
}

/* Header Styles */
.site-header {
  background: #fff;
  height: 142px;
  width: 100%;
  position: fixed;
  z-index: 9;
  top: 0;
}

.hero,
.join-section,
.mtfix {
  margin-top: 8.8em !important;
}

@media all and (max-width:800px) {
  .site-header {
    height: auto !important;
  }

  .mp-0 {
    padding: 10px !important;
  }

  .mp-0 h5 {
    text-align: left;
    padding: 15px !important;
  }

  .hero,
  .join-section,
  .mtfix {
    margin-top: 8.1em !important;
  }

  .navbar-collapse {
    padding: 0 !important;
    box-shadow: none !important;
  }
}

/* Top Bar */
.top-bar {
  border-bottom: 1px solid #e7e7e7;
}

.lang-select {
  border: 1px solid #e9ecef;
  border-radius: 20px;
  padding: 4px 15px;
  font-size: 13px;
  color: var(--muted);
  background: #fff;
  outline: none;
}

/* Social Icon Squares */
.social-box {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #e9ecef;
  color: var(--muted);
  text-decoration: none;
  font-size: 14px;
  transition: 0.3s;
}

.social-box.fb {
  background-color: var(--accent);
  /* The red background for FB in your image */
  color: white;
  border-color: var(--accent);
}

.social-box:hover {
  background-color: var(--accent);
  color: white !important;
  border-radius: 50%;
  border: none !important;
}

/* Logo and Branding */
.logo-img {
  width: 50px;
  height: auto;
}

.brand-text-wrapper {
  line-height: .8;
}

.brand-name {
  display: block;
  font-size: 28px;
  font-weight: 700;
  color: var(--accent);
  /* Red title color */
}

.brand-sub {
  font-size: 12px;
  color: var(--muted);
  font-weight: 500;
}

/* Navigation Links */
.navbar-nav .nav-link {
  font-weight: 500;
  color: var(--muted);
  font-size: 16px;
  transition: 0.3s;
  padding: 5px 1rem !important;
  border-radius: 999px;
  transition: all .2s;
}

.navbar-nav .nav-link.active,
.navbar-nav .nav-link:hover {
  background: var(--accent);
  color: #fff !important;
  box-shadow: var(--shadow-card);
  /* Active Red */
}

/* Join the Movement Button */
.join-btn {
  background-color: var(--accent);
  /* Specific red from image */
  color: white;
  border-radius: 30px;
  padding: 10px 25px;
  font-weight: 600;
  border: none;
  font-size: 15px;
  box-shadow: 0 4px 10px rgba(239, 68, 68, 0.2);
}

.join-btn:hover {
  background-color: #dc2626;
  color: white;
  transform: translateY(-1px);
}

.py1 {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

/* Mobile Tweak */
@media (max-width: 991px) {
  /* .top-bar {
    display: none;
  } */

  nav {
    padding: 10px 0 !important;
  }

  /* .mt1 {
    margin-top: 2em !important;
  } */

  .mb1 {
    margin-bottom: 3px !important;
  }

  /* Hide top bar on mobile for cleaner look */
  .navbar-collapse {
    background: white;
    padding: 20px;
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.1);
  }
}

/* HEADER ends here */
/* ===== Hero ===== */
.hero {
  position: relative;
  background-image: url('../images/hero-banner.jpg');
  background-size: cover;
  background-position: center;
  padding: 2rem 1rem 0 1rem;
  z-index: 1;
}

/* Overlay layer */
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0);
  /* dark overlay */
  z-index: -1;
}

.hero .container {
  position: relative;
  z-index: 2;
}

.hero-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: .4rem 1rem;
  font-size: .75rem;
  font-weight: 600;
  color: var(--sky-deep);
  text-transform: uppercase;
  letter-spacing: .5px;
  box-shadow: var(--shadow-card);
}

.hero-title {
  font-size: clamp(1.5rem, 5.5vw, 5rem);
  line-height: 1.05;
  margin: 1.25rem 0;
}

.hero-title2 {
  font-size: clamp(1.5rem, 6.5vw, 5.5rem) !important;
}

.hero-lead {
  font-size: 1.125rem;
  color: var(--muted);
  max-width: 540px;
}


.hero-portrait-wrap img {
  width: 100%;
  height: auto;
  display: block;
}

.floating-badge {
  position: relative;
  border-radius: 1rem;
  font-size: 1.3rem;
  font-weight: 600;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: .8rem;
}

.floating-badge .dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--darkblue);
  box-shadow: 0 0 0 4px rgba(25, 170, 237, .18);
  animation: pulse 2s infinite;
}

.fb-top {
  top: 1.5rem;
  left: -1rem;
}

.fb-bottom {
  bottom: 0rem;
  right: 4em;
  color: var(--accent);
}

.fb-bottom .dot {
  background: white;
  box-shadow: 0 0 0 4px #2a88c4;
}

@keyframes pulse {

  0%,
  100% {
    opacity: 1;
  }

  50% {
    opacity: .55;
  }
}

@media all and (max-width:800px) {
  .fb-bottom {
    right: 0 !important;
    text-align: center;
    justify-content: center;
  }

  .mhide {
    display: none;
  }

  .header-actions {
    display: block !important;
    align-items: center;
  }

  .joinbtn {
    position: relative;
    left: 0 !important;
  }

  .congresslogo {
    height: 3em;
    margin: 0 1em;
    /* position: relative; */
    /* left: 0 !important; */
  }

  #mainNav {
    text-align: center;
    margin-top: 2em;
  }

  /* Mobile position */
  .mobile-lang {
    position: fixed;
    top: 10px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 9999;
  }

  /* #google_translate_element {
    top: 4px;
    position: fixed;
    margin: 0 auto;
    left: 25%;
  } */
  .mobile-margin {
    border-top: 1px solid black;
    margin-top: 3em;
    padding-top: 1.31em;
  }

  .congresslogo {
    margin: 1em 0 !important;
  }

  .icon-wrap {
    display: none;
  }

  /* campaing page form btn */
  button.btn.bg-red.text-white.btn-lg.w-100.fw-semibold.mt-4 {
    font-size: 12px;
  }

  .join-section {
    padding: 3rem 0rem !important;
  }
}

/* boigraphy */
.journey {
  /* background: linear-gradient(180deg, #ffffff 0%, #d6effc 100%); */
  background: linear-gradient(180deg, #ffffff 0%, #006db421 100%);
}

.eyebrow {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--darkblue);
  padding: 6px 14px;
  border: 1px solid rgba(25, 170, 237, 0.3);
  border-radius: 999px;
  background: rgba(25, 170, 237, 0.08);
  margin-bottom: 18px;
}

/*  */
/* ===== Section ===== */
.section {
  padding: 5rem 0;
}

.section-title-wrap {
  max-width: 720px;
  margin: 0 auto 3rem;
  text-align: center;
}

.section-eyebrow {
  display: inline-block;
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--accent);
  margin-bottom: .75rem;
}

.section-title {
  font-size: clamp(1.85rem, 4.5vw, 2.75rem);
  margin-bottom: 1rem;
}

.section-lead {
  color: var(--muted);
  font-size: 1.6rem;
}

/* p {
  text-align: justify;
  text-justify: inter-word;
  hyphens: auto;
  word-break: break-word;
} */
/* ===== Public Service ---  A Decade of Showing Up ----Cards ===== */
.role-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 1.25rem;
  padding: 1.75rem;
  height: 100%;
  transition: all .3s;
  position: relative;
  overflow: hidden;
}

.role-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--gradient-primary);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .35s;
}

.role-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-elegant);
  border-color: rgba(25, 170, 237, .4);
}

.role-card:hover::before {
  transform: scaleX(1);
}

.role-card .role-icon {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(25, 170, 237, .15), rgba(18, 103, 168, .1));
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--darkblue);
  margin-bottom: 1rem;
  font-size: 1.25rem;
}

.role-card h4 {
  font-size: 1.15rem;
  margin: .25rem 0 .35rem;
}

.role-card .role-period {
  font-size: .75rem;
  font-weight: 600;
  color: var(--darkblue);
  text-transform: uppercase;
  letter-spacing: .12em;
}

/* ===== Vision section ===== */
/* ---------- Vision ---------- */
.vision {
  position: relative;
  color: #fff;
  /* background:
    linear-gradient(135deg, rgba(15, 39, 72, 0.93), rgba(31, 111, 209, 0.85)),
    url('../images/punjab-fields.jpg') center/cover no-repeat; */
  background:
    linear-gradient(135deg, rgba(15, 39, 72, 0.93), #006db4de),
    url('../images/punjab-fields.jpg') center/cover no-repeat;
}

.vision h2,
.vision h3 {
  color: #fff;
}

.vision p {
  color: #fff;
}

.vision .pull-quote {
  /* font-style: italic; */
  font-size: clamp(1.4rem, 2.6vw, 2rem);
  line-height: 1.35;
  border-left: 4px solid var(--accent);
  padding-left: 22px;
  margin-bottom: 28px;
  color: #fff;
}

.vision .signature {
  margin-top: 28px;
}

/* impacts */
.justice-highlight {
  transition: transform 0.3s ease;
}

.justice-highlight:hover {
  transform: translateX(10px);
}

.impact-wrapper {
  transition: all 0.4s ease;
}

.bg-red-soft {
  background-color: rgba(57, 123, 230, 0.1) !important;
}

/* ends here */
/* ===== CTA / Join ===== */
.join-section {
  background: #fff;
  border-radius: 2rem;
  padding: 3rem 2rem;
  text-align: center;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-card);
  position: relative;
  overflow: hidden;
}

.join-section::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(25, 170, 237, .12), transparent 50%),
    radial-gradient(circle at 80% 80%, rgba(217, 38, 59, .08), transparent 50%);
  pointer-events: none;
}

.join-section>* {
  position: relative;
  z-index: 1;
}

/* ===== Stats ===== */
.stat-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 1.25rem;
  padding: 1.75rem 1.25rem;
  text-align: center;
  height: 100%;
  transition: transform .3s;
}

.stat-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-card);
}

.stat-num {
  font-size: 2.25rem;
  font-weight: 800;
  background: var(--gradient-primary);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  line-height: 1;
}

.stat-label {
  margin-top: .5rem;
  font-size: .8rem;
  font-weight: 600;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: .12em;
}

/* ===== Achievement cards ===== */
.achv-card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 1.25rem;
  padding: 1.75rem;
  height: 100%;
  position: relative;
  overflow: hidden;
  transition: all .3s;
}

.achv-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-elegant);
  border-color: rgba(25, 170, 237, .3);
}

.achv-tag {
  display: inline-block;
  background: rgba(25, 170, 237, .1);
  color: var(--sky-deep);
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  padding: .25rem .65rem;
  border-radius: 999px;
  margin-bottom: .85rem;
}

.achv-card h4 {
  font-size: 1.15rem;
  margin-bottom: .5rem;
}

.achv-card p {
  color: var(--muted);
  font-size: .95rem;
  margin: 0;
}

/* new */
/* ---------- Achievements (cards) ---------- */
.achievements {
  background: #ffffff;
}

.achievement-card {
  background: #fff;
  /* border: 1px solid var(--border); */
  border-radius: var(--radius);
  padding: 25px;
  height: 100%;
  /* box-shadow: var(--shadow-card); */
  transition: transform .3s ease, box-shadow .3s ease, border-color .3s ease;
  position: relative;
  overflow: hidden;
  transition: all .5s ease-in-out;
}

.achievement-card::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: var(--gradient-accent);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform .3s ease;
}

/* .achievement-card:hover {
  transform: translateY(-6px);
  border-color:#c822106e;
  box-shadow: var(--shadow-elegant-red);
  border-radius: 10px !important;
} */
.achievement-card:hover {
  transform: translateY(-6px);
  border-color: #ffffff6e;
  border-radius: 10px !important;
  background: var(--sky-bright);
  /* background: var(--accent); */
  color: #fff;
}

.achievement-card:hover h4,
.achievement-card:hover p {
  color: #fff !important;
}

.achievement-card:hover::before {
  transform: scaleY(1);
}

.achievement-icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  background: var(--accent);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  margin-bottom: 20px;
  box-shadow: 0 12px 24px -12px rgba(25, 170, 237, 0.7);
}

.achievement-card h4 {
  font-size: 1.6rem;
  margin-bottom: 10px;
  color: var(--accent);
}

.achievement-card p {
  font-size: .95rem;
  margin: 0;
  line-height: 1.2;
  color: var(--secondary);
}

/* ------------------------ */



/* ===== Footer ===== */
.site-footer {
  position: relative;
  /* position: absolute;
  bottom: 0;
  width: 100%; */

  background: linear-gradient(24deg, #006db4 0%, #006db4e0 60%, #074f86 100%);
  color: rgba(255, 255, 255, .85);
  overflow: hidden;
}

.site-footer .container {
  position: relative;
}

.site-footer h5 {
  color: #fff;
  font-size: .8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .18em;
  margin-bottom: 1.25rem;
}

.site-footer a {
  color: rgba(255, 255, 255, .75);
}

.site-footer a:hover {
  color: #fff;
}

.footer-brand {
  display: flex;
  align-items: center;
  gap: .75rem;
  margin-bottom: 1rem;
}

.footer-brand .brand-mark {
  background: rgba(255, 255, 255, .1);
  border: 1px solid rgba(255, 255, 255, .2);
  box-shadow: none;
}

.footer-quote {
  font-style: italic;
  color: rgba(255, 255, 255, .9);
  margin-top: 1rem;
}

.social-icon {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .1);
  border: 1px solid rgba(255, 255, 255, .18);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  margin-right: .5rem;
  transition: all .25s;
}

.social-icon:hover {
  background: var(--accent);
  border-color: var(--accent);
  transform: translateY(-3px);
  color: #fff;
}

.footer-bottom {
  border-top: 1px solid rgba(255, 255, 255, .12);
  padding: 1.25rem 0;
  font-size: .8rem;
  color: rgba(255, 255, 255, .6);
}

/* ===== Page hero (smaller) ===== */
.page-hero {
  position: relative;
  background: var(--gradient-hero);
  padding: 4.5rem 0 3rem;
  text-align: center;
  overflow: hidden;
}

.page-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(25, 170, 237, .15) 1px, transparent 0);
  background-size: 28px 28px;
  opacity: .35;
}

.page-hero .container {
  position: relative;
}

.page-hero h1 {
  font-size: clamp(2.25rem, 4.5vw, 3.5rem);
}

/* ===== Responsive ===== */
@media (max-width: 768px) {

  /* .hero {
    padding: 3rem 4rem 0 4rem;
  } */
  .section {
    padding: 3.5rem 0;
  }

  .vision {
    padding: 4rem 0;
  }

  /* .bio-content p:first-of-type::first-letter {
    font-size: 3rem;
  } */
}

/*loader*/
#loader-wrapper {
  position: fixed;
  inset: 0;
  background: #ffffff;
  /* White background to match your site */
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 10000;
  transition: opacity 0.6s ease, visibility 0.6s;
}


/* loader css */
.loading-text {
  font-size: 0.9rem;
  letter-spacing: 3px;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--sky-bright);
}

.loader {
  position: relative;
  width: 2.5em;
  height: 2.5em;
  transform: rotate(165deg);

}

.loader:before,
.loader:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  width: 0.5em;
  height: 0.5em;
  border-radius: 0.25em;
  transform: translate(-50%, -50%);
}

.loader:before {
  animation: before8 2s infinite;
}

.loader:after {
  animation: after6 2s infinite;
}

@keyframes before8 {
  0% {
    width: 0.5em;
    box-shadow: 1em -0.5em #c82210b5, -1em 0.5em #c82210b5;
  }

  35% {
    width: 2.5em;
    box-shadow: 0 -0.5em #c82210b5, 0 0.5em #c82210b5;
  }

  70% {
    width: 0.5em;
    box-shadow: -1em -0.5em #c82210b5, 1em 0.5em #c82210b5;
  }

  100% {
    box-shadow: 1em -0.5em #c82210b5, -1em 0.5em #c82210b5;
  }
}

@keyframes after6 {
  0% {
    height: 0.5em;
    box-shadow: 0.5em 1em #c82210b5, -0.5em -1em #c82210b5;
  }

  35% {
    height: 2.5em;
    box-shadow: 0.5em 0 #c82210b5, -0.5em 0 #c82210b5;
  }

  70% {
    height: 0.5em;
    box-shadow: 0.5em -1em #c82210b5, -0.5em 1em #c82210b5;
  }

  100% {
    box-shadow: 0.5em 1em #c82210b5, -0.5em -1em #c82210b5;
  }
}

.loader {
  position: absolute;
  top: calc(40% - 1.25em);
  left: calc(50% - 1.25em);
}

/* ends here */

/* 
.loader {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 15px;
}

.icon {
  height: 3rem;
  width: 3rem;
  animation: spin 1s linear infinite;
  stroke: #006db4;
}

.loading-text {
  font-size: 0.9rem;
  letter-spacing: 3px;
  text-transform: uppercase;
  font-weight: 700;
  color: #006db4;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

.loader-hidden {
  opacity: 0;
  visibility: hidden;
} */

/*ends hre*/
/* key acheivements */
.ach-section {
  padding: 50px 0 40px 0;
  overflow: hidden;
  position: relative;
}

/* subtle radial glow behind cards */
.ach-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 55% at 50% 60%, rgba(229, 57, 53, .15) 0%, transparent 70%);
  pointer-events: none;
}

.ach-title {
  font-family: 'Playfair Display', serif;
  color: white;
  font-size: clamp(28px, 5vw, 44px);
  text-align: center;
  letter-spacing: -.5px;
  margin-bottom: 56px;
}

.ach-title span {
  color: var(--accent);
}

/* ── VIEWPORT ─────────────────────────────── */
.ach-viewport {
  position: relative;
  width: 100%;
  /* show exactly 3 cards + gaps */
  max-width: calc(var(--card-w) * 3 + var(--gap) * 4);
  margin: 0 auto;
  overflow: hidden;
  padding: 50px 12px;
  /* room for icon overhang at top */
}

/* ── TRACK ────────────────────────────────── */
.ach-track {
  display: flex;
  gap: var(--gap);
  will-change: transform;
  transition: transform .48s cubic-bezier(.4, 0, .2, 1);
  padding: 0 var(--gap);
}

/* ── ITEM ─────────────────────────────────── */
.ach-item {
  flex: 0 0 var(--card-w);
  display: flex;
  justify-content: center;
  transition: opacity .4s, transform .4s;
  /* opacity: .38; */
  transform: scale(.9);
}

.ach-item.active {
  opacity: 1;
  transform: scale(1);
}

/* ── Key Achievements css CARD ─────────────────────────────────── */
.ach-card {
  width: 100%;
  background: white;
  border-radius: 50px;
  padding: 60px 30px 20px 30px;
  text-align: center;
  position: relative;
  transition: background .4s, box-shadow .4s;
}

.ach-item.active .ach-card {
  /* background: var(--accent); */
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.175);
  color: var(--accent);
}

.ach-icon {
  position: absolute;
  top: -16%;
  left: 50%;
  transform: translateX(-50%);
  width: 90px;
  height: 90px;
  border-radius: 50%;
  background: var(--sky-bright);
  border: 6px solid white;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: box-shadow .4s;
  font-size: 25px;
}

.ach-item.active .ach-icon {
  box-shadow: 0 6px 24px rgb(0 0 0 / 40%);
  background-color: var(--accent);
}

.ach-card h5 {
  font-size: 18px;
  color: white;
  margin-bottom: 10px;
}

.ach-card p {
  font-size: 15px;
  font-weight: 400;
}

/* ── BUTTONS ──────────────────────────────── */
.ach-btn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 20;
  width: 45px;
  height: 45px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, .18);
  background: rgb(255 255 255 / 95%);
  backdrop-filter: blur(8px);
  color: var(--accent);
  font-size: 22px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .2s, border-color .2s, transform .15s;
  line-height: 1;
}

.ach-btn:hover {
  background: white !important;
  transform: translateY(-50%) scale(1.08);
}

.ach-btn:active {
  transform: translateY(-50%) scale(.96);
}

.ach-btn.prev {
  left: 2px;
}

.ach-btn.next {
  right: 10px;
}

/* ── DOTS ─────────────────────────────────── */
.ach-dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 28px;
}

.ach-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .25);
  transition: background .3s, transform .3s;
  cursor: pointer;
}

.ach-dot.active {
  background: var(--accent);
  transform: scale(1.35);
}

/* ── MOBILE ───────────────────────────────── */
@media (max-width: 768px) {
  :root {
    --card-w: 78vw;
    --gap: 16px;
  }

  .ach-viewport {
    max-width: 100vw;
  }

  .ach-btn.prev {
    left: 8px;
  }

  .ach-btn.next {
    right: 8px;
  }

  .ach-item {
    opacity: .3;
    transform: scale(.88);
  }

  .ach-item.active {
    opacity: 1;
    transform: scale(1);
  }
}

/* ends here */
/* ---------- Final CTA ---------- */
.btn-danger:hover {
  background-color: #d62839;
  border-color: #d62839;
  transform: translateY(-2px);
}

.transition-all {
  transition: all 0.3s ease;
}

.cta-card {
  background-image: radial-gradient(circle at top right, rgba(230, 57, 70, 0.03), transparent);
}

.btn-cta {
  background: var(--accent);
  color: #fff;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  letter-spacing: 0.04em;
  transition: all 0.25s ease;
}

.btn-cta:hover {
  background: var(--sky-bright);
  color: #fff;
  transform: translateY(-2px);
}

.btn-arrow-circle {
  width: 18px;
  height: 18px;
  border: 1.5px solid rgba(255, 255, 255, 0.55);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ends here */
.it-blog-item:hover {
  box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
}

/* blog page  and bog details*/
.blogbtn:hover {
  background-color: var(--accent) !important;
  color: white;
}

.blogbox:hover,
.blogbox:hover div,
.blogbox:hover h5 ,
.blogbox:hover p{
  /* color: var(--accent) !important;
  background: #b1b1b1;
  border-radius: 20px; */
  color: #ffffff !important;
  background: #c82210;
  border-radius: 13px;

}

.blogimage {
  overflow: hidden;
  /* transition: all 23s ease-in-out; */
}

.blogimage img {
  -webkit-transform: scale(1);
  transform: scale(1);
  transition: all .45s ease-in-out;

}

.blogimage:hover img {
  transform: scale(1.1);
}


/* ends here */





/* biography  JOurney */


.card-body {
  padding: 0;
  margin-top: 1em;
}

.journey-timeline {
  padding: 1rem 0;
}

h2.text-blue.fw-bold.mb-1 {
  font-size: 1.4em !important;
}

p.text-muted.mb-0 {
  font-size: 14px;
}

.timeline-dot {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  border: 4px solid #fff;
  position: relative;
  z-index: 2;
  margin-bottom: 1rem;
}

.h-70 {
  height: 70%;
}

.timeline-content .card {
  border-radius: 14px;
  /* transition: transform .25s ease, box-shadow .25s ease; */
  transition: all 1s ease-in-out;
}



.timeline-content .card:hover {
  transform: translateY(-4px);
  box-shadow: 0 .75rem 1.5rem rgba(0, 0, 0, .08) !important;
  background-color: var(--sky-bright);
}

/* ✅ Force child text to white on hover */
.timeline-content .card:hover h2,
.timeline-content .card:hover p,
.timeline-content .card:hover .text-blue,
.timeline-content .card:hover .text-muted {
  color: white !important;
}

@media (max-width: 991.98px) {
  .card-body {
    padding: 1rem !important;
  }

  .timeline-line {
    position: absolute;
    left: 27px;
    top: 0;
    bottom: 0;
    width: 3px;
    background: var(--sky-bright);
    border-radius: 3px;
    z-index: 1;
  }

  .timeline-item {
    padding-left: 70px;
    position: relative;
  }

  .timeline-content {
    display: block;
  }

  .timeline-dot {
    position: absolute;
    left: 0;
    top: 29%;
    margin-bottom: 0;
  }
}

@media (min-width: 992px) {
  .timeline-line {
    position: absolute;
    top: 44px;
    left: 5%;
    right: 5%;
    height: 3px;
    background: var(--sky-bright);
    border-radius: 3px;
    z-index: 1;
  }

  .timeline-item {
    display: flex;
    justify-content: center;
  }

  .timeline-content {
    width: 90%;
  }
}



/* ends here  */




/* ====================================
   WOW ANIMATION BASE
==================================== */

.wow {
  visibility: hidden;
}

.wow.animate,
.wow.animated {
  visibility: visible;
  animation-fill-mode: both;
}

/* ====================================
   FADE IN
==================================== */

.fadeIn {
  animation-name: fadeIn;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

/* ====================================
   FADE IN UP
==================================== */

.fadeInUp {
  animation-name: fadeInUp;
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translate3d(0, 70px, 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

/* ====================================
   FADE IN DOWN
==================================== */

.fadeInDown {
  animation-name: fadeInDown;
}

@keyframes fadeInDown {
  from {
    opacity: 0;
    transform: translate3d(0, -70px, 0);
  }

  to {
    opacity: 1;
    transform: translate3d(0, 0, 0);
  }
}

/* ====================================
   ZOOM IN
==================================== */

.zoomIn {
  animation-name: zoomIn;
}

@keyframes zoomIn {
  from {
    opacity: 0;
    transform: scale3d(.6, .6, .6);
  }

  50% {
    opacity: 1;
  }

  to {
    transform: scale3d(1, 1, 1);
  }
}

/* ====================================
   ZOOM IN UP
==================================== */

.zoomInUp {
  animation-name: zoomInUp;
}

@keyframes zoomInUp {
  from {
    opacity: 0;
    transform: scale3d(.5, .5, .5) translate3d(0, 100px, 0);
  }

  60% {
    opacity: 1;
    transform: scale3d(1.05, 1.05, 1.05) translate3d(0, -10px, 0);
  }

  to {
    transform: scale3d(1, 1, 1) translate3d(0, 0, 0);
  }
}

/* ====================================
   ZOOM IN DOWN
==================================== */

.zoomInDown {
  animation-name: zoomInDown;
}

@keyframes zoomInDown {
  from {
    opacity: 0;
    transform: scale3d(.5, .5, .5) translate3d(0, -100px, 0);
  }

  60% {
    opacity: 1;
    transform: scale3d(1.05, 1.05, 1.05) translate3d(0, 10px, 0);
  }

  to {
    transform: scale3d(1, 1, 1) translate3d(0, 0, 0);
  }
}





/* ====================================
   COMMON ANIMATION SETTINGS
==================================== */
.fadeIn,
.fadeInUp,
.fadeInDown,
.zoomIn,
.zoomInUp,
.zoomInDown {
  animation-duration: 1s;
  animation-fill-mode: both;
}



.borderrightleft {
  border-left: 4px solid var(--accent);

  border-right: 4px solid var(--accent);
}
