body { 
  background: linear-gradient(135deg, #a1c4fd 0%, #c2e9fb 100%); /* Changed to a fresh blue gradient */
      min-height: 100vh;
      position: relative;
      overflow-x: hidden;
    
}
.container { max-width: 600px; }

    .bg-slide {
      position: fixed;
      top: 0; left: 0;
      width: 100vw;
      height: 100vh;
      z-index: 0;
      background: url('https://images.unsplash.com/photo-1464983953574-0892a716854b?auto=format&fit=crop&w=1200&q=80') center/cover no-repeat, url('https://images.unsplash.com/photo-1506744038136-46273834b3fb?auto=format&fit=crop&w=1200&q=80') right/cover no-repeat;
      opacity: 0.18;
      animation: slideBg 18s linear infinite alternate, fadeBg 8s ease-in-out infinite alternate;
    }
    @keyframes slideBg {
      0% { background-position: 0% 50%, 100% 50%; }
      100% { background-position: 100% 50%, 0% 50%; }
    }
    @keyframes fadeBg {
      0% { opacity: 0.18; }
      50% { opacity: 0.28; }
      100% { opacity: 0.18; }
    }
    .navbar {
      background: linear-gradient(90deg, #ff5e62 0%, #ffb347 50%, #43c6ac 100%) !important;
      box-shadow: 0 4px 24px rgba(67,198,172,0.15);
    }
    .navbar-brand {
      font-size: 2rem;
      font-weight: bold;
      color: #fff !important;
      letter-spacing: 2px;
      text-shadow: 1px 2px 8px #43c6ac99;
    }
    .nav-link, .dropdown-toggle {
      color: #fff !important;
      font-weight: 500;
      letter-spacing: 1px;
    }
    .hero-section {
      padding: 5rem 0 3rem 0;
      background: linear-gradient(135deg, #c2e9fb 0%, #a1c4fd 100%); /* Match hero section to new body color */
      text-align: center;
    }
    .hero-title {
      font-size: 2.8rem;
      font-weight: bold;
      color: #ff5e62;
      margin-bottom: 1rem;
      letter-spacing: 1px;
      text-shadow: 1px 2px 8px #43c6ac99;
    }
    .hero-desc {
      font-size: 1.3rem;
      color: #333;
      margin-bottom: 2rem;
    }
    .btn-gradient {
      background: linear-gradient(90deg, #4756ff 0%, #8743c6 100%);
      color: #fff;
      border: none;
      font-weight: 600;
      box-shadow: 0 2px 8px #43c6ac33;
      font-size: 1.2rem;
      padding: 0.75rem 2.5rem;
      border-radius: 2rem;
    }
    .btn-gradient:hover {
      background: linear-gradient(90deg, #43c6ac 0%, #ffb347 100%);
      color: #fff;
    }
    .section-title {
      color: #43c6ac;
      font-weight: bold;
      margin-bottom: 2rem;
      letter-spacing: 1px;
      text-align: center;
    }
    .feature-card {
      background: #fff;
      border-radius: 1rem;
      box-shadow: 0 4px 24px rgba(67,198,172,0.10);
      padding: 2rem 1.5rem;
      margin-bottom: 1.5rem;
      transition: transform 0.2s;
      text-align: center;
    }
    .feature-card:hover {
      transform: translateY(-5px) scale(1.03);
      box-shadow: 0 8px 32px rgba(67,198,172,0.18);
    }
    .testimonial {
      background: #fff;
      border-radius: 1rem;
      box-shadow: 0 4px 24px rgba(67,198,172,0.10);
      padding: 2rem 1.5rem;
      margin-bottom: 1.5rem;
      font-style: italic;
    }
    .contact-section {
      background: #fff;
      border-radius: 1rem;
      box-shadow: 0 4px 24px rgba(67,198,172,0.10);
      padding: 2rem 1.5rem;
      margin-bottom: 2rem;
    }
    .navbar {
      background: linear-gradient(90deg, #ff5e6156 0%, #5e421b45 50%, #43c6ac0f 100%) !important;
      box-shadow: 0 4px 24px rgba(67,198,172,0.15);
    }
    .navbar-brand {
      font-size: 2rem;
      font-weight: bold;
      color: #fff !important;
      letter-spacing: 2px;
      text-shadow: 1px 2px 8px #43c6ac99;
    }
    .nav-link, .dropdown-toggle {
      color: #fff !important;
      font-weight: 500;
      letter-spacing: 1px;
    }
    .hero-section {
      padding: 5rem 0 3rem 0;
      background: linear-gradient(135deg, #c2e9fb 0%, #a1c4fd 100%); /* Match hero section to new body color */
      text-align: center;
    }
    .hero-title {
      font-size: 2.8rem;
      font-weight: bold;
      color: #ff5e62;
      margin-bottom: 1rem;
      letter-spacing: 1px;
      text-shadow: 1px 2px 8px #43c6ac99;
    }
    .hero-desc {
      font-size: 1.3rem;
      color: #333;
      margin-bottom: 2rem;
    }
    .btn-gradient {
      background: linear-gradient(90deg, #ffb347 0%, #43c6ac 100%);
      color: #fff;
      border: none;
      font-weight: 600;
      box-shadow: 0 2px 8px #43c6ac33;
      font-size: 1.2rem;
      padding: 0.75rem 2.5rem;
      border-radius: 2rem;
    }
    .btn-gradient:hover {
      background: linear-gradient(90deg, #43c6ac 0%, #ffb347 100%);
      color: #fff;
    }
    .section-title {
      color: #43c6ac;
      font-weight: bold;
      margin-bottom: 2rem;
      letter-spacing: 1px;
      text-align: center;
    }
    .feature-card {
      background: #fff;
      border-radius: 1rem;
      box-shadow: 0 4px 24px rgba(67,198,172,0.10);
      padding: 2rem 1.5rem;
      margin-bottom: 1.5rem;
      transition: transform 0.2s;
      text-align: center;
    }
    .feature-card:hover {
      transform: translateY(-5px) scale(1.03);
      box-shadow: 0 8px 32px rgba(67,198,172,0.18);
    }
    .testimonial {
      background: #fff;
      border-radius: 1rem;
      box-shadow: 0 4px 24px rgba(67,198,172,0.10);
      padding: 2rem 1.5rem;
      margin-bottom: 1.5rem;
      font-style: italic;
    }
    .contact-section {
      background: #fff;
      border-radius: 1rem;
      box-shadow: 0 4px 24px rgba(67,198,172,0.10);
      padding: 2rem 1.5rem;
      margin-bottom: 2rem;
    }
    .navbar {
      background: linear-gradient(90deg, #bc5eff 0%, #4797ff 50%, #43c6ac 100%) !important;
      box-shadow: 0 4px 24px rgba(67,198,172,0.15);
    }
    .navbar-brand {
      font-size: 2rem;
      font-weight: bold;
      color: #fff !important;
      letter-spacing: 2px;
      text-shadow: 1px 2px 8px #43c6ac99;
    }
    .nav-link, .dropdown-toggle {
      color: #fff !important;
      font-weight: 500;
      letter-spacing: 1px;
    }
    .hero-section {
      padding: 5rem 0 3rem 0;
      background: linear-gradient(135deg, #c2e9fb 0%, #a1c4fd 100%); /* Match hero section to new body color */
      text-align: center;
    }
    .hero-title {
      font-size: 2.8rem;
      font-weight: bold;
      color: #ff5e62;
      margin-bottom: 1rem;
      letter-spacing: 1px;
      text-shadow: 1px 2px 8px #68d1bc99;
    }
    .hero-desc {
      font-size: 1.3rem;
      color: #333;
      margin-bottom: 2rem;
    }
    .btn-gradient {
      background: linear-gradient(90deg, #ffb347 0%, #43c6ac 100%);
      color: hsl(0, 0%, 100%);
      border: none;
      font-weight: 600;
      box-shadow: 0 2px 8px #43c6ac33;
      font-size: 1.2rem;
      padding: 0.75rem 2.5rem;
      border-radius: 2rem;
    }
    .btn-gradient:hover {
      background: linear-gradient(90deg, #43c6ac 0%, #ffb347 100%);
      color: #fff;
    }
    .section-title {
      color: #43c6ac;
      font-weight: bold;
      margin-bottom: 2rem;
      letter-spacing: 1px;
      text-align: center;
    }
    .feature-card {
      background: #fff;
      border-radius: 1rem;
      box-shadow: 0 4px 24px rgba(67,198,172,0.10);
      padding: 2rem 1.5rem;
      margin-bottom: 1.5rem;
      transition: transform 0.2s;
      text-align: center;
    }
    .feature-card:hover {
      transform: translateY(-5px) scale(1.03);
      box-shadow: 0 8px 32px rgba(67,198,172,0.18);
    }
    .testimonial {
      background: #fff;
      border-radius: 1rem;
      box-shadow: 0 4px 24px rgba(67,198,172,0.10);
      padding: 2rem 1.5rem;
      margin-bottom: 1.5rem;
      font-style: italic;
    }
    .contact-section {
      background: #fff;
      border-radius: 1rem;
      box-shadow: 0 4px 24px rgba(67,198,172,0.10);
      padding: 2rem 1.5rem;
      margin-bottom: 2rem;
    }
    .navbar {
      background: linear-gradient(90deg, #ff5e62 0%, #ffb347 50%, #43c6ac 100%) !important;
      box-shadow: 0 4px 24px rgba(67,198,172,0.15);
    }
    .navbar-brand {
      font-size: 2rem;
      font-weight: bold;
      color: #fff !important;
      letter-spacing: 2px;
      text-shadow: 1px 2px 8px #43c6ac99;
    }
    .nav-link, .dropdown-toggle {
      color: #fff !important;
      font-weight: 500;
      letter-spacing: 1px;
    }
    .hero-section {
      padding: 5rem 0 3rem 0;
      background: linear-gradient(135deg, #c2e9fb 0%, #a1c4fd 100%); /* Match hero section to new body color */
      text-align: center;
    }
    .hero-title {
      font-size: 2.8rem;
      font-weight: bold;
      color: #ff5e62;
      margin-bottom: 1rem;
      letter-spacing: 1px;
      text-shadow: 1px 2px 8px #43c6ac99;
    }
    .hero-desc {
      font-size: 1.3rem;
      color: #333;
      margin-bottom: 2rem;
    }
    .btn-gradient {
      background: linear-gradient(90deg, #ffb347 0%, #43c6ac 100%);
      color: #fff;
      border: none;
      font-weight: 600;
      box-shadow: 0 2px 8px #43c6ac33;
      font-size: 1.2rem;
      padding: 0.75rem 2.5rem;
      border-radius: 2rem;
    }
    .btn-gradient:hover {
      background: linear-gradient(90deg, #43c6ac 0%, #ffb347 100%);
      color: #fff;
    }
    .section-title {
      color: #43c6ac;
      font-weight: bold;
      margin-bottom: 2rem;
      letter-spacing: 1px;
      text-align: center;
    }
    .feature-card {
      background: #fff;
      border-radius: 1rem;
      box-shadow: 0 4px 24px rgba(67,198,172,0.10);
      padding: 2rem 1.5rem;
      margin-bottom: 1.5rem;
      transition: transform 0.2s;
      text-align: center;
    }
    .feature-card:hover {
      transform: translateY(-5px) scale(1.03);
      box-shadow: 0 8px 32px rgba(67,198,172,0.18);
    }
    .testimonial {
      background: #fff;
      border-radius: 1rem;
      box-shadow: 0 4px 24px rgba(67,198,172,0.10);
      padding: 2rem 1.5rem;
      margin-bottom: 1.5rem;
      font-style: italic;
    }
    .contact-section {
      background: #fff;
      border-radius: 1rem;
      box-shadow: 0 4px 24px rgba(67,198,172,0.10);
      padding: 2rem 1.5rem;
      margin-bottom: 2rem;
    }
    .voting-bg-image {
      position: fixed;
      top: 0;
      left: 0;
      width: 100vw;
      height: 100vh;
      z-index: 1;
      pointer-events: none;
      opacity: 0.18;
      background: url('assets/vote-for-india.png') center/contain no-repeat;
    }
    .eci-bg-image {
      position: fixed;
      top: 0;
      left: 0;
      width: 100vw;
      height: 100vh;
      z-index: 1;
      pointer-events: none;
      opacity: 0.13;
      background: url('assets/eci-logo.png') center/contain no-repeat;
    }
  
    .bg-slide-admin {
      position: fixed;
      top: 0; left: 0;
      width: 100vw;
      height: 100vh;
      z-index: 0;
      background: url('https://images.unsplash.com/photo-1519125323398-675f0ddb6308?auto=format&fit=crop&w=1200&q=80') center/cover no-repeat;
      opacity: 0.15;
      animation: slideBgAdmin 18s linear infinite alternate;
    }
    @keyframes slideBgAdmin {
      0% { background-position: 0% 50%; }
      100% { background-position: 100% 50%; }
    }
    .admin-card {
      background: linear-gradient(135deg, #e0c3fc 0%, #8ec5fc 100%); /* Soft purple-blue gradient */
      border-radius: 2rem;
      box-shadow: 0 12px 48px rgba(67,198,172,0.18), 0 2px 12px #ff5e6299;
      padding: 3rem 2.5rem;
      max-width: 650px;
      margin: 4rem auto;
      position: relative;
      overflow: hidden;
      z-index: 1;
      border: 4px solid #43c6ac;
      animation: floatCard 3.5s ease-in-out infinite alternate, fadeInUp 1.2s;
    }
    @keyframes floatCard {
      0% { transform: translateY(0) scale(1); box-shadow: 0 8px 40px 0 rgba(255,94,98,0.18), 0 1.5px 8px 0 #43c6ac55; }
      100% { transform: translateY(-18px) scale(1.03); box-shadow: 0 16px 60px 0 rgba(67,198,172,0.18), 0 3px 16px 0 #ff5e6299; }
    }
    @keyframes fadeInUp {
      0% { opacity: 0; transform: translateY(60px); }
      100% { opacity: 1; transform: translateY(0); }
    }
    .admin-title {
      font-weight: bold;
      color: #8f5fe8;
      letter-spacing: 2px;
      text-shadow: 2px 4px 16px #8ec5fc99, 0 1px 0 #fff;
      text-align: center;
      margin-bottom: 2rem;
      font-size: 2.5rem;
      animation: bounceIn 1.2s;
      position: relative;
    }
    @keyframes bounceIn {
      0% { opacity: 0; transform: scale(0.7); }
      60% { opacity: 1; transform: scale(1.1); }
      100% { opacity: 1; transform: scale(1); }
    }
    /* Add animated gradient bar under title */
    .admin-title::after {
      content: '';
      display: block;
      width: 100px;
      height: 8px;
      margin: 22px auto 0 auto;
      border-radius: 4px;
      background: linear-gradient(90deg, #8ec5fc, #e0c3fc, #43c6ac, #ff5e62);
      background-size: 300% 300%;
      animation: gradientBar 2.5s linear infinite alternate;
    }
    @keyframes gradientBar {
      0% { background-position: 0% 50%; }
      100% { background-position: 100% 50%; }
    }
    /* Add animated confetti effect */
    .confetti {
      pointer-events: none;
      position: fixed;
      top: 0; left: 0; width: 100vw; height: 100vh;
      z-index: 10;
      overflow: hidden;
    }
    .confetti-piece {
      position: absolute;
      width: 12px; height: 12px;
      border-radius: 50%;
      opacity: 0.7;
      animation: confetti-fall 3.5s linear infinite;
      box-shadow: 0 0 12px 2px #fff8, 0 0 24px 4px #8ec5fc44;
    }
    @keyframes confetti-fall {
      0% { transform: translateY(-40px) scale(1) rotate(0deg); }
      100% { transform: translateY(100vh) scale(1.2) rotate(360deg); }
    }
    /* Add glassmorphism effect to admin card */
    .admin-card {
      backdrop-filter: blur(8px) saturate(120%);
      background-color: rgba(255,255,255,0.45);
      border: 2px solid rgba(67,198,172,0.18);
    }
    /* Add hover effect to admin card */
    .admin-card:hover {
      transform: scale(1.02) translateY(-8px);
      box-shadow: 0 20px 60px rgba(67,198,172,0.22), 0 4px 24px #ff5e62cc;
      border-color: #8ec5fc;
    }
    
    .bg-slide {
      position: fixed;
      top: 0; left: 0;
      width: 100vw;
      height: 100vh;
      z-index: 0;
      background: url('https://images.unsplash.com/photo-1506744038136-46273834b3fb?auto=format&fit=crop&w=1200&q=80') center/cover no-repeat;
      opacity: 0.18;
      animation: slideBg 18s linear infinite alternate;
    }
    @keyframes slideBg {
      0% { background-position: 0% 50%; }
      100% { background-position: 100% 50%; }
    }
    .auth-card {
      background: linear-gradient(135deg, #e0eafc 0%, #cfdef3 100%); /* Changed to a light blue box */
      border-radius: 1.5rem;
      box-shadow: 0 6px 32px rgba(67,198,172,0.15);
      padding: 2.5rem 2rem;
      max-width: 420px;
      margin: 4rem auto;
      position: relative;
      overflow: hidden;
    }
    .auth-card::before {
      content: '';
      position: absolute;
      top: -60px; left: -60px;
      width: 120px; height: 120px;
      background: linear-gradient(135deg, #43c6ac 0%, #ffb347 100%);
      border-radius: 50%;
      opacity: 0.15;
      z-index: 0;
    }
    .toggle-btn {
      cursor: pointer;
      color: #43c6ac;
      text-decoration: underline;
      font-weight: 500;
    }
    .form-title {
      font-weight: bold;
      color: #43c6ac;
      letter-spacing: 1px;
    }
    .brand {
      font-size: 2rem;
      font-weight: bold;
      color: #ff5e62;
      letter-spacing: 2px;
      text-align: center;
      margin-bottom: 1.5rem;
      text-shadow: 1px 2px 8px #43c6ac99;
    }
    .btn-gradient {
      background: linear-gradient(90deg, #321b1b 0%, #d9e343 100%);
      color: #fff;
      border: none;
      font-weight: 600;
      box-shadow: 0 2px 8px #43c6ac33;
    }
    .btn-gradient:hover {
      background: linear-gradient(90deg, #8d43c6 0%, #5e69ff 100%);
      color: #fff;
    }
    .animate__animated { z-index: 1; }
    .form-control.custom-colored {
      background: linear-gradient(90deg, #e0c3fc 0%, #8ec5fc 100%); /* Changed to a soft purple-blue gradient */
      border: 1.5px solid #66a6ff;
      color: #333;
      font-weight: 500;
      transition: box-shadow 0.2s;
    }
    .form-control.custom-colored:focus {
      background: linear-gradient(90deg, #8ec5fc 0%, #e0c3fc 100%); /* Inverse gradient on focus */
      border-color: #89f7fe;
      box-shadow: 0 0 0 0.2rem #8ec5fc55;
      color: #222;
    }
    .auth-card, .brand, #formContainer, .btn-gradient {
      position: relative;
      z-index: 1;
    }
    .eci-bg-image-login {
      position: fixed;
      top: 0;
      left: 0;
      width: 100vw;
      height: 100vh;
      z-index: 1;
      pointer-events: none;
      opacity: 0.13;
      background: url('assets/eci-logo.png') center/contain no-repeat;
    }
  
    .results-card {
      background: #fff;
      border-radius: 1rem;
      box-shadow: 0 4px 24px rgba(0,0,0,0.08);
      padding: 2rem 1.5rem;
      margin-bottom: 1.5rem;
      transition: transform 0.2s;
    }
    .results-card:hover {
      transform: translateY(-5px) scale(1.03);
      box-shadow: 0 8px 32px rgba(0, 0, 0, 0.12);
    }
    .winner-badge {
      background: linear-gradient(90deg, #00c6ff, #0072ff);
      color: #fff;
      border-radius: 2rem;
      padding: 0.25rem 1rem;
      font-size: 1rem;
      margin-left: 0.5rem;
      animation: pulse 1.2s infinite alternate;
    }
    @keyframes pulse {
      0% { box-shadow: 0 0 0 0 #0072ff44; }
      100% { box-shadow: 0 0 0 8px #0072ff11; }
    }
     .thankyou-bg {
      background: linear-gradient(135deg, #f8ffae 0%, #43c6ac 100%);
      min-height: 100vh;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    .thankyou-card {
      background: #fff;
      border-radius: 1.5rem;
      box-shadow: 0 6px 32px rgba(67,198,172,0.15);
      padding: 3rem 2rem;
      max-width: 420px;
      margin: auto;
    }
    .confetti {
      font-size: 2rem;
      animation: confetti-fall 1.5s infinite alternate;
    }
    @keyframes confetti-fall {
      0% { transform: translateY(0); }
      100% { transform: translateY(10px) rotate(5deg); }
    }
    