:root {
  --sky-deep: #1f3b73;
  --sky-mid: #3358a2;
  --sand-light: #f7efe1;
  --sand-main: #e6ba7a;
  --sand-dark: #be7d3a;
  --leaf: #32654f;
  --ink: #1e2530;
  --soft-card: #fffdfa;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: "Hind", sans-serif;
  color: var(--ink);
  line-height: 1.65;
  background:
    radial-gradient(circle at 15% 20%, rgba(255, 225, 181, 0.35), transparent 40%),
    radial-gradient(circle at 80% 90%, rgba(202, 235, 223, 0.38), transparent 40%),
    #fcfaf5;
}

.top-strip {
  background: #15305d;
  color: #e8f0ff;
  font-size: 0.92rem;
}

.top-strip a {
  color: #f8f3dd;
  text-decoration: none;
}

.top-strip a:hover {
  color: #ffffff;
}

.lang-switch {
  border: 1px solid rgba(255, 255, 255, 0.35);
  border-radius: 999px;
  padding: 0.15rem 0.65rem;
  font-size: 0.82rem;
  line-height: 1.5;
  font-weight: 700;
  text-decoration: none;
  color: #fff8d8;
}

.lang-switch:hover {
  color: #ffffff;
  border-color: rgba(255, 255, 255, 0.65);
  background: rgba(255, 255, 255, 0.12);
}

.social-mini {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}

.social-mini a,
.social-links a {
  width: 30px;
  height: 30px;
  display: inline-grid;
  place-items: center;
  border-radius: 50%;
  text-decoration: none;
  transition: transform 0.2s ease, background-color 0.2s ease, color 0.2s ease;
}

.social-mini a {
  color: #f3f8ff;
  background: rgba(255, 255, 255, 0.16);
}

.social-mini a:hover {
  color: #ffffff;
  background: rgba(255, 255, 255, 0.28);
  transform: translateY(-2px);
}

.navbar {
  background: rgba(255, 251, 245, 0.93);
  backdrop-filter: blur(7px);
  border-bottom: 1px solid rgba(56, 78, 126, 0.12);
}

.navbar-brand {
  font-family: "Teko", sans-serif;
  font-size: 1.85rem;
  letter-spacing: 0.4px;
  color: var(--sky-deep);
}

.brand-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: inline-block;
  background: linear-gradient(120deg, #f3a847, #c66c2d);
  margin-right: 0.3rem;
}

.navbar-nav .nav-link {
  font-weight: 600;
  color: #334155;
  margin-left: 0.4rem;
}

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus {
  color: var(--sand-dark);
}

.nav-lang {
  display: flex;
  align-items: center;
  gap: 0.35rem;
}

.lang-option {
  display: inline-block;
  padding: 0.32rem 0.7rem;
  border-radius: 999px;
  border: 1px solid #ccd8ee;
  background: #f6f9ff;
  color: #274268;
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.2;
  text-decoration: none;
}

.lang-option:hover {
  color: #1f3350;
  border-color: #9db4d8;
}

.lang-option.active {
  color: #fff;
  border-color: #2f5f95;
  background: linear-gradient(125deg, #3c6ea9, #2f5f95);
}

.hero-section {
  position: relative;
  overflow: hidden;
  padding: 5.5rem 0 4.5rem;
  background:
    linear-gradient(160deg, rgba(20, 52, 109, 0.95), rgba(40, 82, 161, 0.82)),
    repeating-linear-gradient(
      -25deg,
      rgba(255, 255, 255, 0.05),
      rgba(255, 255, 255, 0.05) 14px,
      rgba(255, 255, 255, 0.01) 14px,
      rgba(255, 255, 255, 0.01) 26px
    );
}

.hero-tag {
  display: inline-block;
  color: #fceec8;
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: 999px;
  padding: 0.4rem 0.95rem;
  font-size: 0.92rem;
  margin-bottom: 1.2rem;
}

.hero-section h1 {
  color: #ffffff;
  font-family: "Teko", sans-serif;
  font-size: clamp(2.6rem, 5vw, 4.4rem);
  line-height: 0.95;
  margin-bottom: 1rem;
  letter-spacing: 0.4px;
}

.hero-lead {
  color: rgba(255, 255, 255, 0.88);
  font-size: 1.07rem;
  max-width: 590px;
}

.hero-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

.hero-pills span {
  background: rgba(255, 255, 255, 0.15);
  color: #ecf8ff;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 999px;
  padding: 0.5rem 0.9rem;
  font-size: 0.9rem;
}

.hero-pills a {
  color: #f5f4cb;
  text-decoration: none;
}

.sub-hero {
  background:
    linear-gradient(150deg, rgba(22, 64, 50, 0.92), rgba(37, 94, 74, 0.84)),
    repeating-linear-gradient(
      -30deg,
      rgba(255, 255, 255, 0.04),
      rgba(255, 255, 255, 0.04) 12px,
      rgba(255, 255, 255, 0.01) 12px,
      rgba(255, 255, 255, 0.01) 24px
    );
}

.badge-green {
  color: #daf8df;
  border-color: rgba(216, 255, 218, 0.5);
}

.btn-sand {
  background: linear-gradient(125deg, #f0c37f, #d48a45);
  border: 0;
  color: #2b2217;
  font-weight: 700;
  padding: 0.67rem 1.2rem;
}

.btn-sand:hover {
  color: #20180f;
  background: linear-gradient(125deg, #f4cf95, #cb7d36);
}

.village-scene {
  position: relative;
  min-height: 360px;
  border-radius: 26px;
  background: linear-gradient(to bottom, #9bd5ff 0%, #b8e7ff 45%, #f3deba 46%, #ebcd95 100%);
  box-shadow: 0 24px 50px rgba(9, 18, 39, 0.28);
  overflow: hidden;
  border: 2px solid rgba(255, 255, 255, 0.5);
}

.sun {
  position: absolute;
  top: 42px;
  right: 66px;
  width: 74px;
  height: 74px;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, #fff2b8, #f9b233);
  animation: glow 3.2s ease-in-out infinite alternate;
}

.cloud {
  position: absolute;
  height: 26px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.9);
}

.cloud::before,
.cloud::after {
  content: "";
  position: absolute;
  background: rgba(255, 255, 255, 0.9);
  border-radius: 50%;
}

.cloud::before {
  width: 20px;
  height: 20px;
  top: -11px;
  left: 8px;
}

.cloud::after {
  width: 30px;
  height: 30px;
  top: -16px;
  right: 10px;
}

.cloud-1 {
  width: 88px;
  top: 58px;
  left: 20px;
  animation: cloud-float 10s linear infinite;
}

.cloud-2 {
  width: 108px;
  top: 106px;
  left: 120px;
  animation: cloud-float 13s linear infinite reverse;
}

.dune {
  position: absolute;
  border-radius: 50%;
}

.dune-back {
  width: 330px;
  height: 140px;
  bottom: 78px;
  left: -26px;
  background: #d5a86d;
}

.dune-front {
  width: 420px;
  height: 190px;
  bottom: -62px;
  right: -70px;
  background: #c98d4f;
}

.field-strip {
  position: absolute;
  width: 100%;
  height: 70px;
  bottom: 0;
  background:
    repeating-linear-gradient(
      -12deg,
      #5f8b4e 0,
      #5f8b4e 12px,
      #7ea161 12px,
      #7ea161 22px
    );
}

.pond-scene .pond {
  position: absolute;
  width: 240px;
  height: 78px;
  border-radius: 90px;
  bottom: 44px;
  left: 38px;
  background: radial-gradient(circle at 50% 45%, #9ce9ff, #55b9df);
  border: 3px solid rgba(208, 242, 255, 0.65);
  animation: water-wave 3s ease-in-out infinite;
}

.pond-scene .grass {
  position: absolute;
  width: 72px;
  height: 16px;
  border-radius: 24px;
  background: #4e8f5d;
}

.pond-scene .grass::before,
.pond-scene .grass::after {
  content: "";
  position: absolute;
  width: 14px;
  height: 28px;
  background: #2f6b48;
  border-radius: 10px;
  top: -20px;
}

.pond-scene .grass::before {
  left: 14px;
}

.pond-scene .grass::after {
  right: 12px;
}

.pond-scene .grass-1 {
  bottom: 112px;
  left: 44px;
}

.pond-scene .grass-2 {
  bottom: 108px;
  left: 220px;
}

.house {
  position: absolute;
  bottom: 56px;
  left: 82px;
  width: 86px;
  height: 62px;
  background: #fff5de;
  border-radius: 3px;
  box-shadow: inset 0 0 0 2px rgba(144, 91, 48, 0.3);
}

.house::before {
  content: "";
  position: absolute;
  left: -8px;
  top: -24px;
  width: 102px;
  height: 28px;
  background: #a5482f;
  clip-path: polygon(0% 100%, 50% 0%, 100% 100%);
}

.house::after {
  content: "";
  position: absolute;
  width: 20px;
  height: 30px;
  bottom: 0;
  left: 33px;
  background: #81552a;
  border-radius: 2px;
}

.tree {
  position: absolute;
  bottom: 58px;
  width: 12px;
  height: 54px;
  background: #66492f;
}

.tree::before {
  content: "";
  position: absolute;
  left: -16px;
  top: -28px;
  width: 42px;
  height: 34px;
  border-radius: 55% 45% 55% 45%;
  background: #3d7f59;
  animation: sway 3.1s ease-in-out infinite;
  transform-origin: center bottom;
}

.tree-1 {
  left: 205px;
}

.tree-2 {
  left: 242px;
  height: 46px;
}

.windmill {
  position: absolute;
  right: 70px;
  bottom: 70px;
  width: 8px;
  height: 90px;
  background: #604a35;
}

.windmill .rotor {
  position: absolute;
  left: -3px;
  top: -6px;
  width: 12px;
  height: 12px;
  animation: spin 3s linear infinite;
}

.windmill span {
  position: absolute;
  left: 0;
  top: 5px;
  width: 64px;
  height: 2px;
  background: #ecf4fa;
  transform-origin: 6px 1px;
}

.windmill span:nth-child(2) {
  transform: rotate(90deg);
}

.windmill span:nth-child(3) {
  transform: rotate(45deg);
}

.windmill span:nth-child(4) {
  transform: rotate(135deg);
}

.section-space {
  padding: 5rem 0;
}

.section-soft {
  background:
    linear-gradient(180deg, rgba(255, 247, 236, 0.8), rgba(242, 250, 255, 0.9));
}

.section-title {
  font-family: "Teko", sans-serif;
  font-size: clamp(2rem, 4vw, 3rem);
  color: #2a3450;
  letter-spacing: 0.3px;
  margin-bottom: 0.5rem;
}

.section-text {
  color: #3f4654;
  font-size: 1.04rem;
}

.section-muted {
  color: #5b6475;
}

.goal-box {
  background: linear-gradient(145deg, #fff7e8, #fffdf9);
  border: 1px solid rgba(190, 125, 58, 0.25);
  border-radius: 18px;
  padding: 1.5rem;
  box-shadow: 0 12px 28px rgba(127, 89, 42, 0.08);
}

.goal-box h5 {
  color: #a35e28;
  font-weight: 700;
}

.goal-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  padding: 0.35rem 0;
}

.goal-list i {
  color: #2c7b59;
  margin-top: 0.2rem;
}

.service-card {
  background: var(--soft-card);
  border: 1px solid #ece2d1;
  border-radius: 18px;
  padding: 1.5rem;
  transition: transform 0.28s ease, box-shadow 0.28s ease, border-color 0.28s ease;
  box-shadow: 0 10px 25px rgba(31, 44, 69, 0.06);
}

.service-card .icon {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  margin-bottom: 0.95rem;
  background: linear-gradient(145deg, #ffe1b8, #f4c07d);
  color: #91561f;
  font-size: 1.45rem;
}

.service-card h5 {
  color: #25314a;
  margin-bottom: 0.4rem;
}

.service-card p {
  margin: 0;
  color: #4e5766;
}

.service-card:hover {
  transform: translateY(-8px);
  border-color: #dfbe8a;
  box-shadow: 0 18px 28px rgba(31, 44, 69, 0.13);
}

.highlight-panel {
  border-radius: 20px;
  background: linear-gradient(145deg, #fffdf8, #fff4e1);
  border: 1px solid rgba(189, 123, 55, 0.3);
  padding: 2rem;
}

.long-card {
  border-radius: 18px;
  background: #fffefa;
  border: 1px solid #e6d8c0;
  box-shadow: 0 12px 24px rgba(44, 54, 79, 0.08);
  padding: 1.4rem;
}

.long-card h5 {
  color: #274267;
  font-weight: 700;
}

.initiative-card {
  border-radius: 16px;
  border: 1px solid #deead9;
  background: linear-gradient(145deg, #f8fff6, #fdfef8);
  box-shadow: 0 10px 20px rgba(35, 61, 45, 0.08);
  padding: 1.3rem;
  transition: transform 0.24s ease, box-shadow 0.24s ease;
}

.initiative-card h5 {
  color: #1f4a3e;
  margin-bottom: 0.65rem;
}

.initiative-card p {
  color: #475569;
  margin: 0;
}

.initiative-card:hover {
  transform: translateY(-7px);
  box-shadow: 0 16px 24px rgba(35, 61, 45, 0.13);
}

.step-chip {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #f5efe3;
  border: 1px solid #e8d6ba;
  border-radius: 12px;
  padding: 0.6rem 0.8rem;
  margin-bottom: 0.55rem;
}

.step-chip span {
  color: #475569;
  font-weight: 600;
}

.step-chip strong {
  color: #2d4d7d;
}

.timeline-vertical {
  border-left: 2px dashed #9cb9d7;
  padding-left: 1.2rem;
}

.timeline-entry {
  position: relative;
  margin-bottom: 1rem;
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid #e2e8f0;
  padding: 1rem;
  box-shadow: 0 8px 20px rgba(20, 33, 62, 0.07);
}

.timeline-entry::before {
  content: "";
  position: absolute;
  left: -1.6rem;
  top: 1.2rem;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #2f5f95;
}

.timeline-entry h6 {
  color: #264266;
  margin-bottom: 0.35rem;
}

.timeline-entry p {
  margin: 0;
  color: #526072;
}

.data-table-wrap {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 8px 20px rgba(20, 33, 62, 0.06);
}

.data-table-wrap thead th {
  background: #edf3fb;
  color: #223f64;
  font-weight: 700;
}

.faq-box .accordion-item {
  border: 1px solid #dae7dc;
}

.faq-box .accordion-button {
  font-weight: 600;
  color: #224a3d;
}

.faq-box .accordion-button:not(.collapsed) {
  background: #edf9ef;
  color: #184134;
}

.section-divider {
  border-top: 5px solid #d89b56;
}

.progress-item {
  margin-bottom: 1rem;
}

.progress-item span {
  font-weight: 600;
  color: #3d4557;
}

.bar {
  height: 9px;
  background: #eadfcf;
  border-radius: 999px;
  overflow: hidden;
  margin-top: 0.42rem;
}

.bar span {
  display: block;
  height: 100%;
  border-radius: 999px;
  background: linear-gradient(90deg, #4f81bf, #2f5f95);
  animation: grow 1.2s ease forwards;
}

.mini-stat {
  border-radius: 16px;
  background: #ffffff;
  border: 1px solid #e8e8e8;
  box-shadow: 0 8px 20px rgba(31, 44, 69, 0.07);
  padding: 1.2rem;
  text-align: center;
}

.mini-stat h3 {
  font-family: "Teko", sans-serif;
  font-size: 2rem;
  margin: 0;
  color: #2e4f83;
}

.mini-stat p {
  margin: 0.25rem 0 0;
  color: #5f6672;
}

.contact-tile {
  background: #fff;
  border-radius: 18px;
  padding: 1.4rem;
  border: 1px solid #e9ddcb;
  box-shadow: 0 10px 20px rgba(39, 45, 61, 0.07);
}

.contact-tile p {
  margin-bottom: 0.76rem;
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  color: #4a5565;
}

.contact-tile i {
  color: #2e6c53;
  margin-top: 0.2rem;
}

.contact-tile a {
  color: #2c5083;
  text-decoration: none;
}

.contact-tile a:hover {
  text-decoration: underline;
}

.social-links {
  display: flex;
  gap: 0.55rem;
}

.social-links a {
  color: #294a78;
  background: #edf3ff;
}

.social-links a:hover {
  background: #d8e6ff;
  color: #173a66;
  transform: translateY(-2px);
}

.contact-form {
  border-radius: 18px;
  border: 1px solid #e9dfcf;
  background: #fffcf7;
  padding: 1.4rem;
  box-shadow: 0 16px 24px rgba(31, 44, 69, 0.08);
}

#formAlert,
#formAlertHariyali,
.form-alert-box {
  border-radius: 12px;
  margin-bottom: 0.85rem;
}

.form-control {
  border-radius: 10px;
  border: 1px solid #d7dde8;
  padding: 0.7rem 0.88rem;
}

.form-control:focus {
  border-color: #6b8fc2;
  box-shadow: 0 0 0 0.22rem rgba(107, 143, 194, 0.2);
}

.site-footer {
  background: #1d2740;
  color: #e7ebf6;
}

.footer-links {
  font-size: 0.95rem;
}

.footer-links a {
  color: #cdd7ee;
  text-decoration: none;
}

.footer-links a:hover {
  color: #ffffff;
}

.footer-links span {
  color: #7f8ca8;
  margin: 0 0.25rem;
}

.site-footer small {
  color: #bfc8db;
}

.reveal {
  opacity: 0;
  transform: translateY(34px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}

.reveal.show {
  opacity: 1;
  transform: translateY(0);
}

.delay-1 {
  transition-delay: 0.1s;
}

.delay-2 {
  transition-delay: 0.2s;
}

.delay-3 {
  transition-delay: 0.3s;
}

@keyframes cloud-float {
  0% {
    transform: translateX(-10px);
  }
  50% {
    transform: translateX(26px);
  }
  100% {
    transform: translateX(-10px);
  }
}

@keyframes glow {
  0% {
    box-shadow: 0 0 0 rgba(255, 204, 93, 0.35);
    transform: scale(1);
  }
  100% {
    box-shadow: 0 0 28px rgba(255, 187, 51, 0.55);
    transform: scale(1.06);
  }
}

@keyframes sway {
  0%, 100% {
    transform: rotate(-3deg);
  }
  50% {
    transform: rotate(4deg);
  }
}

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

@keyframes grow {
  from {
    width: 0;
  }
}

@keyframes water-wave {
  0%, 100% {
    transform: translateY(0px);
    box-shadow: inset 0 0 0 0 rgba(255, 255, 255, 0.2);
  }
  50% {
    transform: translateY(-3px);
    box-shadow: inset 0 0 16px 0 rgba(255, 255, 255, 0.28);
  }
}

@media (max-width: 991px) {
  .top-strip {
    font-size: 0.85rem;
  }

  .nav-lang {
    margin-top: 0.55rem;
  }

  .hero-section {
    padding-top: 4.2rem;
  }

  .village-scene {
    min-height: 320px;
  }

  .pond-scene .pond {
    width: 210px;
  }
}

@media (max-width: 767px) {
  .section-space {
    padding: 3.6rem 0;
  }

  .hero-section h1 {
    line-height: 1;
  }

  .village-scene {
    min-height: 280px;
  }

  .sun {
    width: 58px;
    height: 58px;
    right: 28px;
    top: 25px;
  }

  .house {
    left: 45px;
  }

  .tree-1 {
    left: 162px;
  }

  .tree-2 {
    left: 190px;
  }

  .windmill {
    right: 42px;
    height: 80px;
  }

  .pond-scene .pond {
    width: 176px;
    left: 22px;
    bottom: 40px;
  }

  .pond-scene .grass-1 {
    left: 24px;
  }

  .pond-scene .grass-2 {
    left: 156px;
  }
}
