/* ============================================================
   top.css
   ============================================================ */

:root {
  --parkingArea: #b9e1ff;
  --areaSpace: 40px;
  --areaPadding: 2em;
}

@media screen and (max-width: 768px) {
  :root {
    --areaSpace: 24px;
    --areaPadding: 1em;
  }
}
/* 交通案内 2列グリッド */
.access-parking {
  margin-top: 40px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px 48px;
  border-top: 1px solid var(--border);
  padding-top: 40px;
}
.parking-block {
  display: flex;
  flex-direction: column;
  gap: 16px;
  background: rgba(124, 92, 58, 0.07);
  border-radius: 16px;
  padding: 28px 32px;
}

/* アイコン＋見出し行 */
.parking-title-row {
  display: flex;
  align-items: center;
  gap: 12px;
}
.parking-icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  color: var(--brown);
  display: flex;
  align-items: center;
  justify-content: center;
}
.parking-icon svg {
  width: 100%;
  height: 100%;
}
.parking-title {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: var(--text-md);
  font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--black);
}
.parking-text {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: var(--text-base);
  font-weight: 300;
  color: var(--black);
  line-height: 1.9;
  letter-spacing: 0.04em;
  padding-left: 48px; /* アイコン幅分インデント */
}
.parking-text small {
  display: block;
  font-size: var(--text-base);
  color: var(--gray);
  margin-top: 3px;
}
.parking-note {
  grid-column: 1 / -1;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: var(--text-base);
  font-weight: 300;
  color: var(--gray);
  line-height: 1.9;
  padding: 16px 20px;
  background: var(--bg);
  border-left: 3px solid var(--border);
  letter-spacing: 0.03em;
}

.parking-service {
  margin-top: var(--areaSpace);
  border-radius: 10px;
  padding: var(--areaPadding);
  display: flex;
  flex-direction: column; /* 縦並びにする */
  gap: 18px; /* 要素間のスペース */
  background-color: var(--parkingArea);
}
.parking-service h3 {
  text-align: center;
}
.parking-service-grid {
  display: flex;
  gap: 20px; /* 要素の間隔 */
  align-items: center;
  justify-content: space-around;
}

@media (max-width: 768px) {
  /* ACCESSセクション モバイル */
  #access {
    padding: 72px 22px 72px;
  }
  .access-map-wrap {
    padding-top: 72%; /* スマホは縦長に */
  }
  .access-parking {
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .parking-block {
    padding: 22px 24px;
  }
  .parking-text {
    padding-left: 0; /* スマホはインデントなし */
  }
  .parking-service-grid {
    flex-direction: column;
  }
}
