charset "utf-8";


/* フォーム全体の枠組み */
.entry-form {
    width: 80%;
    margin: 0 auto;
    padding: 30px 20px;
    background-color: #ffffff;
    border: 2px solid #aaaaaa;
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
    font-family: sans-serif;
}

/* 注意書きのアラート枠 */
.form-alert {
    background-color: #fff3cd;
    color: #856404;
    border: 1px solid #ffeeba;
    padding: 12px;
    border-radius: 6px;
    font-size: 14px;
    font-weight: bold;
    margin-bottom: 10px;
    text-align: center;
    margin-top: 20px;
}

/* 応募フォーム */


.opinion-box {
    width: 80%;
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    padding-top: 0;
    
}

.opinion-box p {
    line-height: 20px;
}


form {
    width: 100%;
    padding: 20px;

}

.Form {
    margin-left: auto;
    margin-right: auto;
    max-width: 720px;
    padding-top: 0;
    
}

form p {
    text-align: center;
    font-weight: lighter;
    padding-top: 20px;
    
}



/* 入力欄デザイン */

input, select, textarea {
    
    padding: 10px;
    margin-bottom: 15px;
    box-sizing: border-box;
    border: 1px solid #ccc;
    border-radius: 6px;

}

textarea {
    width: 100%;
}

/* ラジオボタン大きさ調整 */
input[type="radio"]{
    width: 16px;
    height: 16px;
    vertical-align: top;
    margin-right: 10px;
    margin-left: 70px;
}

/* 必須項目 */
input :required {
    background:  rgb(245, 211, 198);
}
.required ::after {
    content: "必須";
    background-color: tomato;
    color: #fff;
    text-align: center;
    border-radius: 5px;
}


input :valid {
    background: transparent;
}

input:focus {
    background-color: #ffeeba;
    
}

textarea {
    resize: vertical;
}



textarea:focus {
    background-color: #ffeeba;
    
}
.dob-container {
    display: flex;
    justify-content: space-between;
}

.dob-container select {
    width: calc(33.33% - 5px);
    justify-content: space-between;
}


.note {
    display: inline-block;
    text-align: left;
    margin-bottom: 10px;
    
}







#preferredTime {
    width: 100%;
}

/* 送信ボタン */

.Btn-area {   
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
}

.Form-Btn {
    display: inline-block;
    width: 180px;
    max-width: 100%;
    padding: 10px 20px;
    background-color: #ff831e;
    box-shadow: 0 3px 6px rgba(0, 0, 0, .16);
    color: white;
    font-size: 1rem;
    text-align: center;
    text-decoration: none;
    border-radius: 20px;
    font-weight: bold;
    
}

.Form-Btn:hover {
    background-color: #ffeeba;
    color: #ffffff;
}


h3 {
    font-weight: normal;
}


/* ポスター下の応募ボタン */
.btn01 {
    display: inline-block;
    padding: 20px 30px;
    background-color: #ff831e;
    color: white;
    text-decoration: none;
    border-radius: 30px;
    font-weight: bold;
    margin: 20px;
    box-shadow: 5px 5px 10px rgba(12, 12, 12, 0.16);
}
.btn01:hover {
    background-color: #ffc547;
}

.btn-01 {
    justify-content: center;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
    margin-top: 20px;
}

.btn01:active {
    transform: translateY(3px);
    box-shadow: 0 1px 0 #d65f00;
}

/* 全体を囲むコンテナ */
.event-info-container {
    max-width: 900px;
    margin: 40px auto;
    padding: 0 20px;
    font-family: sans-serif;
    color: #333333;
}

/* 各セクションの共通設定 */
.info-section {
    background: #ffffff;
    border: 1px solid #e0e0e0;
    border-radius: 12px;
    padding: 30px;
    margin-bottom: 30px;
    box-shadow: 0 4px 6px rgba(0, 0, 0, 0.02);
}

.info-section h2 {
    font-size: 20px;
    color: #2d4a22;
    border-bottom: 2px solid #2d4a22;
    padding-bottom: 10px;
    margin-top: 0;
    margin-bottom: 24px;
}

/* タイムライン（スケジュール）のデザイン */
.timeline {
    position: relative;
    border-left: 3px solid #ccc;
    padding-left: 20px;
    margin-left: 10px;
}

.timeline-item {
    position: relative;
    margin-bottom: 25px;
}

/* タイムラインの点を打つ */
.timeline-item::before {
    content: '';
    position: absolute;
    left: -28px;
    top: 5px;
    width: 14px;
    height: 14px;
    background: #ff6f00;
    border: 2px solid #fff;
    border-radius: 50%;
}

/* 納涼祭だけの特別感 */
.timeline-item.festival::before {
    background: #de3a3a;
}

.timeline .time {
    font-weight: bold;
    font-size: 16px;
    color: #ff6f00;
    margin-bottom: 4px;
}

.timeline-item.festival .time {
    color: #de3a3a;
}

.timeline .content h3 {
    margin: 0 0 8px 0;
    font-size: 17px;
}

.timeline .content p {
    margin: 0;
    font-size: 14px;
    color: #666666;
    line-height: 1.6;
}

/* 受付の注意文を強調 */
.highlight-text {
    color: #de3a3a !important;
    font-weight: bold;
    background: #fff0f0;
    padding: 8px 12px;
    border-radius: 6px;
    margin-top: 5px !important;
    border-left: 4px solid #de3a3a;

}

/* 持ち物リストのデザイン */
.belongings-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.belongings-list li {
    position: relative;
    padding-left: 25px;
    margin-bottom: 12px;
    font-size: 15px;
    line-height: 1.5;
}

/* チェックマーク風のアイコン */
.belongings-list li::before {
    content: '✓';
    position: absolute;
    left: 0;
    color: #ff6f00;
    font-weight: bold;
}

/* 注意事項のボックス */
.notice-box {
    background-color: #fafafa;
    border-left: 4px solid #777777;
    padding: 15px 20px;
}

.notice-box ul {
    margin: 0;
    padding-left: 20px;
}

.notice-box li {
    margin-bottom: 12px;
    font-size: 14px;
    line-height: 1.6;
    color: #444444;
}

.notice-box li:last-child {
    margin-bottom: 0;
}

