/* ベース設定 */
body {
    font-family: "Helvetica Neue", Arial, sans-serif;
    background-color: #f0f2f5;
    color: #333;
    padding: 20px;
    margin: 0;
}

.container {
    max-width: 650px;
    margin: 0 auto;
}

header {
    text-align: center;
    margin-bottom: 25px;
}

header h1 { color: #1a73e8; }

/* カードデザイン */
.card {
    background: #fff;
    border-radius: 12px;
    padding: 25px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
    margin-bottom: 20px;
}

h2 {
    font-size: 1.1rem;
    border-left: 5px solid #1a73e8;
    padding-left: 10px;
    margin-bottom: 20px;
}

/* フォーム要素 */
.input-group { display: flex; gap: 10px; }
input[type="text"], input[type="number"], select {
    width: 100%; padding: 12px; border: 1px solid #ddd; border-radius: 6px;
}

.grid-form {
    display: grid; grid-template-columns: 1fr 1fr; gap: 15px;
}

.form-item { margin-bottom: 20px; }
.form-item label { display: block; font-weight: bold; margin-bottom: 8px; font-size: 0.9rem; }

.checkbox-group label {
    display: block; font-weight: normal; margin-bottom: 8px; cursor: pointer;
}

/* ボタン */
button {
    cursor: pointer; padding: 12px 20px; border-radius: 6px; border: none; font-weight: bold; transition: 0.3s;
}

.btn-primary { background-color: #1a73e8; color: white; width: 100%; font-size: 1.1rem; }
.btn-secondary { background-color: #5f6368; color: white; width: 100%; margin-top: 15px; }

.btn-open-map {
    display: block; text-decoration: none; background: #e8f0fe; color: #1a73e8;
    text-align: center; padding: 15px; border-radius: 8px; font-weight: bold; border: 2px solid #1a73e8;
}

/* 特殊ボックス */
.shop-preview-container { margin-bottom: 25px; }
.violation-box { background: #fff5f5; border: 1px solid #feb2b2; padding: 15px; border-radius: 8px; }
.warning-label { color: #c53030 !important; }

/* 結果表示 */
.hidden { display: none; }
.result-container { display: flex; align-items: center; justify-content: space-around; margin: 20px 0; }
.rank-badge { font-size: 80px; font-weight: bold; line-height: 1; }
.score-text { font-size: 20px; font-weight: bold; color: #5f6368; }
.chart-box { max-width: 250px; }
.advice-box { background: #fffaf0; border-left: 5px solid #ed8936; padding: 15px; border-radius: 4px; }
.advice-box ul { padding-left: 20px; font-size: 0.95rem; }