/* 移除 padding 並設定高度 */
html, body {
    margin: 0;
    padding: 0;
    height: 100%; /* 確保滿足 flex 佈局條件 */
}

/* 修正 body 的排版 */
body {
    font-family: Arial, sans-serif;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    justify-content: center; /* 垂直居中 */
    align-items: center; /* 水平居中 */
    min-height: 100vh; /* 確保占滿視窗 */
    background-color: #f5f5f5;
    overflow: hidden;
}

.login {
    background-color: #0b132b;
    width: 400px;
    color: white;
    padding: 50px;
    box-shadow: 10px 10px 25px #00000080;
    text-align: center;
}

.login input {
    display: block;
    margin: 20px auto;
    text-align: center;
    background: none;
    padding: 12px;
    font-size: 15px;
    border-radius: 22px;
    outline: none;
    color: #f8f9fa;
}

.login input[type="text"], .login input[type="password"] {
    border: 2px solid #3498db;
    width: 220px;
}

.login input[type="submit"] {
    width: 250px;
    border: 2px solid #2ecc71;
    cursor: pointer;
}

.login input[type="text"]:focus, .login input[type="password"]:focus {
    border-color: #2ecc71;
    width: 280px;
    transition: 0.5s;
}

.login input[type="submit"]:hover {
    background-color: #2ecc71;
    transition: 0.5s;
}

.login table {
    margin: 0 auto; /* 水平居中 */
    display: block;
}
