/**
 * 抽選応募ページスタイル (bosyu.css)
 * BEM命名規則に近いアプローチでリファクタリング
 */
body {
    background-color: #000!important;
}
.article__contents {
    background-color: #141414!important;
}

h3 {
    color: #fff!important;
}

/* 基本レイアウト */
header {
    display: none;
}

.wrapper {
    margin: 0 auto !important;
}

/* キービジュアルエリア */
.lottery {
    color: #FFFFFF;
}

.lottery__visual {
 
        background-image: url(../images/bosyu.webp);
        background-repeat: no-repeat;
        background-size: 100% auto;
        text-shadow: 3px 3px 3px #000;
        background-position: right top;
        margin-right: auto;
        margin-left: auto;
        padding: 30px 0 15px 0;
  
}

.lottery__heading {
    font-size: 1.1rem;
    margin: 10px 0 0 10px;
    color: #FFFFFF;
    font-weight: bold;
    text-align: left;
}

.lottery__deadline {
    color: #FFFFFF;
    font-size: 1rem;
    width: auto;
    margin: 15px auto 0 auto;
    padding: 7px;
    font-weight: bold;
}

.lottery__notification {
    font-size: 1rem;
    color: #FFFFFF;
    text-align: center;
    font-weight: bold;
    margin: 10px 0;
}

.lottery__weekly {
    font-weight: bold;
    color: #FFFF00;
}

/* フォームエリア */
.lottery__form-container {
    margin: 0 auto;
    width: 95%;
    color: #FFFFFF !important;
}

.lottery__form-group {
    font-size: 1.2rem !important;
    text-align: center;
}

.lottery__input {
    width: 100%;
    max-width: 300px;
    padding: 10px;
    border-radius: 4px;
    border: 1px solid #ccc;
    margin: 0 auto 15px auto;
    display: block;
}

.lottery__submit {
    background-color: #28a745;
    color: white;
    border: none;
    padding: 10px 20px;
    border-radius: 4px;
    cursor: pointer;
    font-weight: bold;
    transition: background-color 0.3s;
    margin: 0 auto;
    display: block;
}

.lottery__submit:hover {
    background-color: #218838;
}

.lottery__note {
    font-size: 0.8rem;
    margin-top: 15px;
    text-align: center;
}

/* 重複応募メッセージ */
.lottery__duplicate-message {
    color: blue;
    font-weight: bold;
    text-align: center;
    padding: 20px;
    margin: 20px 0;
    border: 1px solid #ccc;
    background-color: #f8f8f8;
}

/* メッセージ表示エリア */
.lottery__message {
    background-color: #fff;
    color: #333;
    padding: 20px;
    border-radius: 8px;
    margin: 20px 0;
}

.lottery__message p {
    text-align: center;
}

.lottery__message blockquote {
    margin: 30px 0;
    padding: 15px;
    border: 1px solid #FFFFFF;
    border-radius: 8px;
    background-color: #000;
}

.lottery__message blockquote p {
    color: #FFFFFF !important;
}

.lottery__error {
    background-color: #fff;
    color: #dc3545;
    padding: 15px;
    border-radius: 4px;
    border: 1px solid #dc3545;
}


/* レスポンシブデザイン */
@media screen and (min-width: 768px) {
    .lottery__visual {
        background-image: url(../images/bosyu.webp);
        background-repeat: no-repeat;
        background-size: 100% auto;
        text-shadow: 3px 3px 3px #000;
        background-position: right top;
        margin-right: auto;
        margin-left: auto;
        padding: 100px 0 15px 0;
    }
    
    .lottery__heading {
        font-size: 3rem;
    }
    
    .lottery__deadline {
        font-size: 1.5rem;
        width: 100%;
    }
    
    .lottery__notification {
        font-size: 1.5rem;
    }
    
    .lottery__form-container {
        margin: 0 auto;
        width: 100%;
        max-width: 1000px;
    }
    
    .lottery__input {
        max-width: 400px;
    }
}