* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  background-color: var(--primary-color);
  background-image: url('../images/background-logo.png');
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100% 100%;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
  overflow-x: hidden;
}

.login-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  width: 100%;
  position: relative;
  z-index: 2;
  bottom: 12vh;
}

.logo-container {
  margin-bottom: 40px;
  text-align: center;
}

.logo-container img {
  height: auto;
  max-width: 400px;
}

.login-box {
  background: white;
  border-radius: 15px;
  padding: 40px 30px;
  /* box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1); */
  width: 400px;
  max-width: 90%;
  text-align: center;
  position: relative;
}

.login-box::before {
  content: '';
  position: absolute;
  top: -2px;
  left: -2px;
  right: -2px;
  bottom: -2px;
  background: linear-gradient(45deg, #9A0036, #C41E3A, #9A0036);
  border-radius: 17px;
  z-index: -1;
}

.login-title {
  font-size: 28px;
  color: #333;
  margin-bottom: 8px;
  font-weight: bold;
}

.login-subtitle {
  color: #666;
  font-size: 14px;
  margin-bottom: 30px;
  line-height: 1.4;
}

.google-login-btn {
  width: 100%;
  padding: 12px 20px;
  border: 2px solid #ddd;
  border-radius: 8px;
  background: white;
  color: #333;
  font-size: 16px;
  cursor: pointer;
  transition: all 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.google-login-btn:hover {
  border-color: #9A0036;
  /* box-shadow: 0 2px 8px rgba(154, 0, 54, 0.2); */
}

.google-icon {
  width: 20px;
  height: 20px;
  background: url('data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTgiIGhlaWdodD0iMTgiIHZpZXdCb3g9IjAgMCAxOCAxOCIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48ZyBmaWxsPSJub25lIiBmaWxsLXJ1bGU9ImV2ZW5vZGQiPjxwYXRoIGQ9Ik0xNy42NCA5LjIwNDhjMC0uNjM5LS4wNTctMS4yNTItLjE2NC0xLjg0MUg5djMuNDgxaDQuODQ0Yy0uMjA5IDEuMTI1LS44NDQgMi4wNzgtMS43OTYgMi43MTR2Mi4yNTloMi45MDhjMS43MzQtMS41OTggMi43MzgtMy45NTMgMi43MzgtNi43MTN6IiBmaWxsPSIjNDA5MkZGIi8+PHBhdGggZD0iTTkgMThjMi40MyAwIDQuNDY3LS44MDYgNS45NTYtMi4xOGwtMi45MDgtMi4yNTljLS44MDYuNTQtMS44MzcuODYtMy4wNDguODYtMi4zNDQgMC00LjMyOC0xLjU4NC00LjYzNi0zLjcxMUguOTU3djIuMzMyQzIuNDM4IDE0LjcyIDUuNDgyIDE4IDkgMTh6IiBmaWxsPSIjMzRBODUzIi8+PHBhdGggZD0iTTQuMzY0IDEwLjcxQzQuMTc2IDEwLjE3IDQuMDY4IDkuNTkzIDQuMDY4IDljMC0uNTkzLjEwOC0xLjE3LjI5Ni0xLjcxVjQuOTU3SC45NTdDLjM0NyA2LjE3MyAwIDcuNTQ4IDAgOXMuMzQ3IDIuODI3Ljk1NyA0LjA0M2wzLjQwNy0yLjMzMnoiIGZpbGw9IiNGQkJDMDUiLz48cGF0aCBkPSJNOSAzLjU4Yy0xLjMyMSAwLTIuNTA4LjQ1NC0zLjQ0IDEuMzQ1bDIuNTgyIDIuNTgyQzguODg3IDYuODkxIDguOTI5IDYuNTUgOS4wOSA2LjU1aDMuNDRWMy4xOEgxNi41MTRDMTQuNzI1IDEuMzQgMTIuMDgyIDAgOSAweiIgZmlsbD0iI0VBNDMzNSIvPjwvZz48L3N2Zz4=') no-repeat center;
  background-size: contain;
}

.wave-footer {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  /* background-image: url('../images/wave.gif'); */
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: contain;
  z-index: 1;
}

/* Responsive Design */
@media (max-width: 768px) {
  .logo-container {
      margin-bottom: 30px;
  }
  
  .logo-container img {
      max-width: 350px;
  }
  
  .login-box {
      width: 350px;
      padding: 30px 25px;
      margin: 20px;
  }
  
  .login-title {
      font-size: 24px;
  }
}

@media (max-width: 480px) {
  .logo-container img {
      max-width: 300px;
  }
  
  .login-box {
      width: 300px;
      padding: 25px 20px;
  }
  
  .login-title {
      font-size: 22px;
  }
  
  .google-login-btn {
      font-size: 14px;
      padding: 10px 15px;
  }
} 