/*====================================
  カラーパレット＆変数
====================================*/
:root {
  --primary:        #007acc;
  --primary-hover:  #005f99;
  --radius:         8px;
  --card-bg:        #ffffff;
  --card-shadow:    rgba(0, 0, 0, 0.1);
  --footer-bg:      #f4f4f4;
  --footer-text:    #666;
  --footer-padding: 1.5em;
  --font-family:    'Helvetica Neue', sans-serif;
}

/*====================================
  レイアウト調整（footerを押し下げる）
====================================*/
/* htmlに高さを持たせておく */
html {
  height: 100%;
}
/* bodyを縦方向のflexコンテナにし、
   最低でも画面全体(100vh)を占めるようにする */
body {
  margin:           0;
  padding:          0 1em;
  font-family:      var(--font-family);
  background-color: #f9f9f9;
  color:            #333;

  display:          flex;
  flex-direction:   column;
  min-height:       100vh;
}
/* .containerはbody直下のラッパーなので
   残りの領域を全て使い、かつ内部も縦並び */
.container {
  flex:           1;
  display:        flex;
  flex-direction: column;
}
/* header/main/footer のうち mainだけが伸びる */
.container > main {
  flex: 1;
}

/*====================================
  リセット
====================================*/
*,
*::before,
*::after {
  box-sizing: border-box;
  margin:    0;
  padding:   0;
}

/*====================================
  ヘッダー
====================================*/
header {
  display:        flex;
  justify-content: space-between;
  align-items:     center;
  flex-wrap:       wrap;
  margin:          1em 0;
  gap:             1em;
}
header h1 {
  font-size: 1.6rem;
  color:     var(--primary);
}
.header-buttons {
  display: flex;
  gap:     0.6em;
}
.header-buttons button {
  background-color:    var(--primary);
  color:               #fff;
  border:              none;
  padding:             0.5em 1em;
  border-radius:       var(--radius);
  font-size:           0.95rem;
  cursor:              pointer;
  transition:          background-color 0.2s ease;
}
.header-buttons button:hover {
  background-color: var(--primary-hover);
}

/*====================================
  セレクト群
====================================*/
.select-container {
  display:        flex;
  flex-wrap:      wrap;
  gap:            1em;
  margin-bottom:  2em;
}
.select-block {
  flex:       1 1 auto;
  min-width:  180px;
}
.select-block label {
  display:      block;
  margin-bottom: 0.4em;
  font-weight:  bold;
}
.select-block select {
  width:             100%;
  padding:           0.5em;
  border:            1px solid #ccc;
  border-radius:     var(--radius);
  font-size:         1rem;
  appearance:        none;           /* スマホ用カスタム矢印 */
  background-color:  #fff;
  cursor:            pointer;
  transition:        border-color 0.2s;
}
.select-block select:focus {
  border-color: var(--primary);
  outline:      none;
}

/*─────────────────────────*
  PCではブラウザネイティブの矢印に戻す
*─────────────────────────*/
@media (min-width: 600px) {
  .select-block select {
    appearance:        auto !important;
   -webkit-appearance: auto !important;
   -moz-appearance:    auto !important;
    background-image:  none !important;
  }
}

/*====================================
  結果リスト
====================================*/
#resultList {
  list-style: none;
  padding:    0;
  margin:     0;
  display:    grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap:        1.2em;
}
#resultList li {
  background-color: var(--card-bg);
  border-radius:    var(--radius);
  box-shadow:       0 2px 6px var(--card-shadow);
  padding:          1em;
  display:          flex;
  align-items:      flex-start;
  gap:              0.5em;
  transition:       transform 0.2s ease, box-shadow 0.2s ease;
}
#resultList li:hover {
  transform:    translateY(-4px);
  box-shadow:   0 4px 12px var(--card-shadow);
}
#resultList li input[type="checkbox"] {
  margin-top: 0.3em;
}
#resultList li h2 {
  margin:      0 0 0.5em;
  font-size:   1.1rem;
  color:       var(--primary);
}
#resultList li p {
  margin:     0;
  font-size:  0.95rem;
  color:      #444;
}

/*====================================
  フッター
====================================*/
footer {
  background-color: var(--footer-bg);
  color:            var(--footer-text);
  text-align:       center;
  padding:          var(--footer-padding);
  font-size:        0.9rem;
  margin-top:       2em;  /* 任意で余白調整 */
}

/*====================================
  モバイル対応
====================================*/
@media (max-width: 600px) {
  header {
    flex-direction: column;
    align-items:    center;
    text-align:     center;
  }
  .header-buttons {
    justify-content: center;
  }
  .select-container {
    flex-direction: column;
    align-items:    stretch;
    gap:            0.8em;
    padding:        0.5em 0;
  }
  .select-block {
    width: 100%;
  }
  #resultList {
    grid-template-columns: 1fr;
    gap:                   1em;
  }
}