/* ログイン・承認待ちページ */

.login-body {
    background: var(--color-gray-50);
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

.login-container {
    width: 100%;
    max-width: 420px;
    padding: 20px;
}

.login-card {
    background: white;
    border-radius: 12px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.1);
    padding: 40px 32px;
}

.login-header {
    text-align: center;
    margin-bottom: 32px;
}

.login-logo {
    width: 72px;
    height: 72px;
    margin: 0 auto 12px;
    display: block;
}

.login-header h1 {
    font-size: 24px;
    font-weight: 700;
    color: var(--color-primary);
    margin: 0 0 4px;
}

.login-subtitle {
    font-size: 14px;
    color: var(--color-gray-500);
    margin: 0;
}

/* エラーメッセージ */
.login-error {
    background: #fee2e2;
    color: #dc2626;
    padding: 12px 16px;
    border-radius: 8px;
    font-size: 14px;
    margin-bottom: 20px;
}

/* ボタン共通 */
.login-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    height: var(--control-height);
    padding: 0 16px;
    border: none;
    border-radius: var(--control-border-radius);
    font-size: var(--control-font-size);
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    text-decoration: none;
    box-sizing: border-box;
}

.login-btn-google {
    background: white;
    color: #333;
    border: 1px solid var(--control-border-color);
}

.login-btn-google:hover {
    background: var(--color-gray-50);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.login-btn-email {
    background: var(--color-primary);
    color: white;
}

.login-btn-email:hover {
    background: var(--color-primary-light);
}

.login-btn-register {
    background: white;
    color: var(--color-primary);
    border: 1px solid var(--color-primary);
}

.login-btn-register:hover {
    background: var(--color-primary-lighter);
}

/* 区切り線 */
.login-divider {
    display: flex;
    align-items: center;
    margin: 24px 0;
    gap: 12px;
}

.login-divider::before,
.login-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--color-gray-200);
}

.login-divider span {
    font-size: 13px;
    color: var(--color-gray-400);
}

/* メールフォーム */
.email-login-form .form-group {
    margin-bottom: 16px;
}

.email-login-form label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--color-gray-700);
    margin-bottom: 4px;
}

.email-login-form input {
    width: 100%;
    height: var(--control-height);
    padding: var(--control-padding-y) var(--control-padding-x);
    border: 1px solid var(--control-border-color);
    border-radius: var(--control-border-radius);
    font-size: var(--control-font-size);
    box-sizing: border-box;
}

.email-login-form input:focus {
    outline: 2px solid var(--color-primary);
    outline-offset: -1px;
    border-color: var(--color-primary);
}

/* 新規登録 */
.login-register {
    margin-top: 24px;
    text-align: center;
}

.login-register p {
    font-size: 13px;
    color: var(--color-gray-500);
    margin: 0 0 8px;
}

/* メッセージ */
.login-message {
    margin-top: 16px;
    padding: 12px 16px;
    border-radius: 8px;
    font-size: 14px;
    text-align: center;
}

.login-message.error {
    background: #fee2e2;
    color: #dc2626;
}

.login-message.success {
    background: #d1fae5;
    color: #059669;
}

/* スピナー */
.login-spinner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin-top: 16px;
    color: var(--color-gray-500);
    font-size: 14px;
}

.login-spinner .spinner {
    width: 20px;
    height: 20px;
    border: 2px solid var(--color-gray-200);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

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

/* 承認待ちページ */
.pending-message {
    text-align: center;
    padding: 20px 0;
}

.pending-icon {
    font-size: 48px;
    margin-bottom: 16px;
}

.pending-message h2 {
    font-size: 20px;
    font-weight: 700;
    color: var(--color-primary);
    margin: 0 0 12px;
}

.pending-message p {
    font-size: 14px;
    color: var(--color-gray-600);
    margin: 0 0 4px;
}

.pending-actions {
    margin-top: 32px;
}
