/* ログインページ専用レスポンシブCSS */
/* 375px幅での表示崩れ防止とモバイル最適化 */

/* モバイルファーストの基本スタイル */
@media screen and (max-width: 767px) {
    .login {
        width: 95%;
        padding: 1rem;
        gap: 1.5rem;
        justify-content: unset;
        margin-top: 50px;
    }
    
    .login__logo-list {
        width: 100%;
        flex-direction: column;
        gap: 0;
        align-items: center;
    }
    
    .login__logo {
        width: 80%;
        max-width: 300px;
        height: auto;
        min-height: 60px;
        background-size: contain;
        background-position: center;
    }
    
    .login__container {
        width: 100%;
        max-width: none;
        margin: 1rem auto;
        padding: 1.5rem;
    }
    
    .login__heading {
        font-size: 1.8rem;
        margin-bottom: 1.5rem;
    }
    
    .login__form-group {
        margin-bottom: 1.2rem;
    }
    
    .login__label {
        font-size: 1.4rem;
        margin-bottom: 0.8rem;
    }
    
    .login__input {
        font-size: 1.6rem;
        padding: 1.2rem 1rem;
        min-height: 48px; /* タップターゲットサイズ確保 */
    }
    
    .login__login-button,
    .login__reset-button {
        width: 100%;
        padding: 1.2rem;
        font-size: 1.6rem;
        min-height: 48px;
        margin: 1.5rem 0;
    }
    
    .login__forgot-password {
        margin-top: 1.5rem;
    }
    
    .login__link {
        font-size: 1.4rem;
        padding: 0.8rem;
        display: inline-block;
        min-height: 44px;
        line-height: 1.4;
    }
}

/* 小型スマホ対応（375px以下） */
@media screen and (max-width: 375px) {
    .login {
        width: 98%;
        padding: 0.8rem;
    }
    
    .login__container {
        padding: 1.2rem;
        margin: 0.8rem auto;
    }
    
    .login__heading {
        font-size: 1.6rem;
        margin-bottom: 1.2rem;
    }
    
    .login__logo {
        max-width: 280px;
        min-height: 50px;
    }
    
    .login__input {
        padding: 1rem 0.8rem;
        font-size: 1.6rem;
    }
    
    .login__login-button,
    .login__reset-button {
        padding: 1rem;
        font-size: 1.6rem;
    }
}

/* 超小型スマホ対応（320px以下） */
@media screen and (max-width: 320px) {
    .login {
        width: 100%;
        padding: 0.5rem;
    }
    
    .login__container {
        padding: 1rem;
        margin: 0.5rem auto;
    }
    
    .login__logo {
        max-width: 250px;
        min-height: 45px;
    }
    
    .login__heading {
        font-size: 1.5rem;
        margin-bottom: 1rem;
    }
    
    .login__input {
        padding: 0.8rem;
        font-size: 1.6rem;
    }
    
    .login__login-button,
    .login__reset-button {
        padding: 0.8rem;
        font-size: 1.5rem;
    }
}

/* タブレット対応（768px - 1024px） */
@media screen and (min-width: 768px) and (max-width: 1024px) {
    .login__logo-list {
        width: 80%;
        max-width: 600px;
    }
    
    .login__container {
        width: 60%;
        max-width: 500px;
    }
}

/* 横画面（ランドスケープ）対応 */
@media screen and (max-height: 500px) and (orientation: landscape) {
    .login {
        height: auto;
        min-height: 100vh;
        padding: 1rem;
    }
    
    .login__logo-list {
        flex-direction: row;
        width: 80%;
        max-width: 600px;
        gap: 2rem;
    }
    
    .login__logo {
        max-width: 200px;
        min-height: 40px;
    }
    
    .login__container {
        margin: 1rem auto;
        padding: 1rem;
    }
}
