/* ═══════════════════════════════════════
   WEATHER.CSS — 날씨 위젯 전용 스타일
═══════════════════════════════════════ */

/* ── OPEN INFO 컨테이너 ── */
.open-info-wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  padding: 0 1.25rem 1rem;
  position: relative;
  z-index: 1;
}

/* 카드 기본: 1/3 너비 */
.open-info-card {
  width: calc(33.333% - 0.667rem);
  margin-bottom: 0;
  cursor: default;
}

/* 호버 효과 제거 (클릭 이동 카드 아님) */
.open-info-card:hover {
  transform: none;
  box-shadow: none;
  background: var(--card);
}

[data-theme="dark"] .open-info-card:hover {
  box-shadow: none;
}

/* 모바일: full-width */
@media (max-width: 37.5rem) {
  .open-info-card {
    width: 100%;
  }
}

/* ── 조회 버튼 ── */
.weather-btn {
  display: block;
  width: 100%;
  padding: 0.5rem 0;
  background: transparent;
  border: 1px solid var(--border2);
  border-radius: 2px;
  color: var(--ink2);
  font-family: inherit;
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  cursor: pointer;
  transition:
    border-color var(--transition),
    color var(--transition),
    background var(--transition);
}

.weather-btn:hover:not(:disabled) {
  border-color: var(--accent);
  color: var(--accent);
}

.weather-btn:disabled {
  opacity: 0.5;
  cursor: default;
}

/* ── 구분선 ── */
.weather-rule {
  height: 1px;
  background: var(--border);
  margin: 0.75rem 0;
  transition: background var(--transition);
}

/* ── 날씨 데이터 그리드 (label / value 2열) ── */
.weather-grid {
  display: grid;
  grid-template-columns: 4rem 1fr;
  row-gap: 0.3125rem;
  column-gap: 0.75rem;
}

.weather-label {
  font-size: 0.5625rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink3);
  padding-top: 0.0625rem; /* 베이스라인 정렬 보정 */
  transition: color var(--transition);
}

.weather-value {
  font-size: 0.75rem;
  color: var(--ink2);
  transition: color var(--transition);
}

/* ── 등급 텍스트 ── */
.weather-grade {
  font-size: 0.5625rem;
  letter-spacing: 0.1em;
  margin-left: 0.375rem;
  font-weight: 600;
}

.weather-grade.good    { color: var(--accent); }
.weather-grade.normal  { color: var(--ink2); }
.weather-grade.bad     { color: #c07830; }
.weather-grade.verybad { color: var(--red); }

/* ── 카드 푸터 ── */
.weather-time {
  font-size: 0.5625rem;
  color: var(--ink3);
  letter-spacing: 0.1em;
  transition: color var(--transition);
}

.weather-refresh {
  background: transparent;
  border: none;
  padding: 0;
  font-family: inherit;
  font-size: 0.5625rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--ink3);
  cursor: pointer;
  transition: color var(--transition);
}

.weather-refresh:hover {
  color: var(--accent);
}

/* ── 안내 텍스트 (에러/위치권한 거부 등) ── */
.weather-notice {
  font-size: 0.75rem;
  color: var(--ink3);
  text-align: center;
  padding: 0.25rem 0;
  transition: color var(--transition);
}
