/* Weather tile */
.tile-weather .tile-header h2 { color: var(--cyan); }
.tile-weather .tile-header { cursor: pointer; user-select: none; transition: background 0.15s; }
.tile-weather .tile-header:hover { background: var(--surface2); }
.tile-weather .tile-badge { background: var(--cyan-bg); color: var(--cyan); }

.weather-grid {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.6rem 1.2rem;
  align-items: start;
}
.weather-hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.1rem;
}
.weather-icon { font-size: 2.4rem; line-height: 1; }
.weather-temp {
  font-size: 1.8rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}
.weather-feels {
  font-size: 0.68rem;
  color: var(--text-dim);
}
.weather-details {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}
.weather-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.78rem;
}
.weather-row .wr-label {
  color: var(--text-dim);
  min-width: 70px;
  font-size: 0.7rem;
}
.weather-row .wr-value {
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.weather-decision {
  grid-column: 1 / -1;
  display: flex;
  gap: 0.5rem;
  flex-wrap: wrap;
  margin-top: 0.3rem;
  padding-top: 0.6rem;
  border-top: 1px solid var(--border);
}
.weather-chip {
  font-size: 0.7rem;
  font-weight: 600;
  padding: 0.25rem 0.6rem;
  border-radius: 6px;
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
}
.weather-chip.chip-green { background: var(--green-bg); color: var(--green); }
.weather-chip.chip-red { background: var(--red-bg); color: var(--red); }
.weather-chip.chip-orange { background: var(--orange-bg); color: var(--orange); }
.weather-chip.chip-blue { background: var(--blue-bg); color: var(--blue); }
.weather-chip.chip-cyan { background: var(--cyan-bg); color: var(--cyan); }
.weather-chip.chip-purple { background: var(--purple-bg); color: var(--purple); }
.weather-chip.chip-dim { background: var(--surface2); color: var(--text-dim); }

.weather-section-label {
  grid-column: 1 / -1;
  font-size: 0.65rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-dim);
  margin-top: 0.4rem;
  padding-top: 0.6rem;
  border-top: 1px solid var(--border);
}

/* Detail panel (maximized view) */
.weather-detail { display: none; padding: 0 1rem 1rem; }
.weather-detail.open { display: block; }

/* Overview rows (compact summary) */
.weather-overview-row {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.3rem 0;
}
.weather-overview-row + .weather-overview-row { border-top: 1px solid var(--border); }
.weather-overview-icon { font-size: 1.2rem; line-height: 1; }
.weather-overview-temp {
  font-size: 1rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  min-width: 2.5rem;
}
.weather-overview-hilo {
  font-size: 0.7rem;
  color: var(--text-dim);
  font-variant-numeric: tabular-nums;
  min-width: 3.5rem;
}
.weather-overview-rain {
  font-size: 0.7rem;
  color: var(--cyan);
  font-variant-numeric: tabular-nums;
  min-width: 3rem;
}
.weather-overview-name {
  font-size: 0.7rem;
  color: var(--text-dim);
  margin-left: auto;
  text-align: right;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Multi-location cards */
.weather-loc-card { margin-bottom: 0.6rem; }
.weather-loc-card:last-of-type { margin-bottom: 0; }
.weather-loc-label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--cyan);
  margin-bottom: 0.4rem;
  padding-bottom: 0.3rem;
  border-bottom: 1px solid var(--border);
}
.weather-loc-label .weather-loc-remove {
  font-size: 0.6rem;
  color: var(--text-dim);
  cursor: pointer;
  padding: 0.1rem 0.3rem;
  border-radius: 3px;
}
.weather-loc-label .weather-loc-remove:hover { color: var(--red); background: var(--red-bg); }
.weather-loc-separator {
  border: none;
  border-top: 1px dashed var(--border);
  margin: 0.6rem 0;
}
.weather-manage-bar {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  margin-top: 0.5rem;
  padding-top: 0.4rem;
  border-top: 1px solid var(--border);
}
