/*
 * @File: login.css
 * @Description: 登录页面专用样式文件，实现了表单的居中布局、美化及响应式适配。
 * @Author: Your Name
 * @Date: 2023-10-27
 */

/* --- 全局变量：仅保留毛玻璃参数，移除特定主色调 --- */
:root {
  /* 毛玻璃核心参数（统一控制） */
  --glass-blur: 12px;
  --glass-bg-opacity: 0.2;
  --glass-border-opacity: 0.3;
  /* 文本颜色（基础黑白灰） */
  --text-dark: #212529;
  /* 通用过渡效果 */
  --transition: all 0.2s ease-in-out;
}

/* --- 1. 页面布局与容器样式 --- */
.main-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 130px);
  padding: 2rem 1rem;
}

.page-title {
  font-size: 2rem;
  font-weight: 700;
  color: var(--text-dark);
  margin-bottom: 2rem;
  text-align: center;
}

/* 登录容器毛玻璃优化 */
.login-container {
  width: 100%;
  background-color: rgba(255, 255, 255, var(--glass-bg-opacity));
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  border: 1px solid rgba(255, 255, 255, var(--glass-border-opacity));
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
  border-radius: 30px;
  padding: 50px 100px;
  transition: var(--transition);
}

/* --- 2. 表单元素核心样式 --- */
/* 通用表单组 */
.form-group {
  margin-bottom: 1.5rem;
}

/* 普通输入框标签（块级） */
.form-group label:not([for="remember-me"]) {
  display: block;
  margin-bottom: 0.75rem;
  font-weight: 500;
  color: var(--text-medium);
}

/* 输入框样式（浅白透明） */
.form-group input[type="email"],
.form-group input[type="password"] {
  width: 100%;
  padding: 0.75rem 1rem;
  border: 1px solid rgba(255, 255, 255, 0.5);
  background-color: rgba(255, 255, 255, 0.8);
  border-radius: 0.5rem;
  font-size: 1rem;
  color: var(--text-dark);
  transition: var(--transition);
}

.form-group input[type="email"]:focus,
.form-group input[type="password"]:focus {
  outline: none;
  border-color: rgba(255, 255, 255, 0.8);
  box-shadow: 0 0 0 0.2rem rgba(255, 255, 255, 0.15);
}

/* --- 核心修复：记住我 复选框+标签同行（兼容原HTML，无需改class） --- */
.form-group:has(input[type="checkbox"]) {
  display: flex;
  align-items: center;
  gap: 0.5rem; /* 复选框与标签间距 */
  margin-bottom: 1.5rem;
}

/* 复选框样式 */
.form-group input[type="checkbox"] {
  width: 18px;
  height: 18px;
  cursor: pointer;
  accent-color: var(--text-light); /* 浅灰选中色，不突兀 */
  flex-shrink: 0; /* 防止压缩 */
}

/* 记住我标签样式（行内，无底边距） */
.form-group label[for="remember-me"] {
  display: inline-block;
  margin-bottom: 0;
  font-weight: 400;
  color: var(--text-medium);
  cursor: pointer;
  user-select: none;
}

/* 错误提示（浅白透明毛玻璃） */
.alert-danger {
  background-color: rgba(255, 255, 255, 0.3);
  color: var(--text-medium);
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: 0.5rem;
  padding: 1rem;
  margin-bottom: 1.5rem;
}

.alert-danger p {
  margin-bottom: 0;
}

/* --- 核心优化：纯毛玻璃登录按钮（无特定底色） --- */
#login-btn {
  width: 100%;
  padding: 0.75rem 1rem;
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--text-dark); /* 深灰文字，保证可读性 */
  /* 纯毛玻璃核心（无底色，仅透明+模糊） */
  background-color: rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  /* 浅白边框增强毛玻璃质感 */
  border: 1px solid rgba(255, 255, 255, 0.6);
  border-radius: 0.5rem;
  cursor: pointer;
  transition: var(--transition);
  /* 轻阴影提升层次感，无色彩 */
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

/* 按钮hover：增强毛玻璃透明度+轻微上浮 */
#login-btn:hover {
  background-color: rgba(255, 255, 255, 0.4);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.08);
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.8);
}

/* 底部链接（浅灰，无彩色） */
.form-links {
  display: flex;
  justify-content: space-between;
  margin-top: 1.5rem;
}

.form-links a {
  color: var(--text-light);
  text-decoration: none;
  font-size: 0.9rem;
  transition: var(--transition);
}

.form-links a:hover {
  color: var(--text-dark);
  text-decoration: underline;
}

/* --- 3. 响应式适配 --- */
@media (min-width: 768px) {
  .login-container {
    max-width: 450px;
    margin: 0 auto;
  }
}

@media (max-width: 767.98px) {
  .login-container {
    padding: 1.5rem;
  }
  .page-title {
    font-size: 1.75rem;
  }
  /* 小屏幕复选框适配 */
  .form-group input[type="checkbox"] {
    width: 16px;
    height: 16px;
  }
  /* 小屏幕按钮适配 */
  #login-btn {
    font-size: 1rem;
    padding: 0.7rem 1rem;
  }
}