/* ─── Area Compare ──────────────────────────────────────────────────── */

/* ─── Picker page ─────────────────────────────────────────────────── */

.area-picker-search {
  max-width: 72rem;
}

.area-picker-inputs {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem;
}

@media (min-width: 1024px) {
  .area-picker-inputs {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.area-picker-field {
  position: relative;
}

.area-picker-input {
  width: 100%;
  padding: 0.625rem 0.75rem 0.625rem 2.25rem;
  font-size: 0.875rem;
  color: #1e3329;
  background: #fff;
  border: 1px solid #d1d5db;
  border-radius: 0.5rem;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.area-picker-input:focus {
  outline: none;
  border-color: #008080;
  box-shadow: 0 0 0 3px rgba(0, 128, 128, 0.1);
}

.area-picker-input::placeholder {
  color: #9ca3af;
}

.area-picker-input--plain {
  padding-left: 0.75rem;
}

.area-picker-icon {
  position: absolute;
  left: 0.65rem;
  top: 50%;
  transform: translateY(-50%);
  width: 1rem;
  height: 1rem;
  color: #9ca3af;
  pointer-events: none;
}

.area-picker-results {
  position: absolute;
  top: calc(100% + 0.25rem);
  left: 0;
  right: 0;
  max-height: 16rem;
  overflow-y: auto;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 0.5rem;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  z-index: 20;
  display: none;
}

.area-picker-results--open {
  display: block;
}

.area-picker-item {
  padding: 0.5rem 0.75rem;
  font-size: 0.8125rem;
  cursor: pointer;
  transition: background 0.1s ease;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.area-picker-item:hover,
.area-picker-item--focused {
  background: #f3f4f6;
}

.area-picker-item--selected {
  background: rgba(0, 128, 128, 0.06);
  font-weight: 600;
}

.area-picker-item-district {
  font-size: 0.6875rem;
  color: #9ca3af;
}

/* ─── Selected area chips ─────────────────────────────────────────── */

.area-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  min-height: 2rem;
}

.area-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.625rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #1e3329;
  background: #faf6f0;
  border: 1px solid #d1d5db;
  border-radius: 2rem;
}

.area-chip-remove {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  background: transparent;
  border: none;
  cursor: pointer;
  color: #9ca3af;
  font-size: 0.75rem;
  line-height: 1;
  transition: color 0.15s ease, background 0.15s ease;
  padding: 0;
}

.area-chip-remove:hover {
  color: #ef4444;
  background: rgba(239, 68, 68, 0.08);
}

/* ─── Comparison page: side-by-side cards ────────────────────────── */

.area-compare-grid {
  display: grid;
  gap: 1.25rem;
  align-items: start;
}

.area-compare-grid--2 {
  grid-template-columns: 1fr 1fr;
}

.area-compare-grid--3 {
  grid-template-columns: repeat(3, 1fr);
}

.area-compare-card {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 0.75rem;
  overflow: hidden;
  min-width: 0;
  box-shadow: 0 12px 28px rgba(30, 51, 41, 0.05);
}

.area-compare-hero {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: #e8e1d6;
}

.area-compare-hero-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transform-origin: center center;
  animation: area-compare-hero-camera 18s ease-in-out infinite;
  animation-fill-mode: both;
  transform: scale(1.06) translate3d(0, 0, 0);
}

.area-compare-card-header {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid #f3f4f6;
}

.area-compare-card-title {
  font-size: 1rem;
  font-weight: 700;
  color: #1e3329;
  margin: 0;
  font-family: 'Source Serif 4', 'Times New Roman', serif;
}

.area-compare-card-title a {
  color: inherit;
  text-decoration: none;
  transition: color 0.15s ease;
}

.area-compare-card-title a:hover {
  color: #008080;
}

.area-compare-card-district {
  font-size: 0.6875rem;
  color: #9ca3af;
  margin: 0.125rem 0 0;
}

.area-compare-card-district a {
  color: inherit;
  text-decoration: none;
  transition: color 0.15s ease;
}

.area-compare-card-district a:hover {
  color: #008080;
}

.area-compare-card-body {
  padding: 0.75rem 1rem 1rem;
}

.area-compare-sidecard {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 0.75rem;
  overflow: hidden;
  min-width: 0;
  box-shadow: 0 12px 28px rgba(30, 51, 41, 0.05);
}

.area-compare-sidecard--map {
}

.area-compare-sidecard-header {
  padding: 0.85rem 1rem 0.7rem;
  border-bottom: 1px solid #f3f4f6;
}

.area-compare-sidecard-title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  color: #1e3329;
}

.area-compare-sidecard-subtitle {
  margin: 0.18rem 0 0;
  font-size: 0.6875rem;
  color: #9ca3af;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.area-compare-mini-map {
  height: 16rem;
  background: #f6efde;
}

.area-compare-mini-map--empty {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  background: #f8fafc;
}

.area-compare-mini-map-empty-text {
  margin: 0;
  font-size: 0.8rem;
  color: #6b7280;
  text-align: center;
}

/* ─── Metric rows (reuses compare pattern) ────────────────────────── */

.area-metric {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 0.3rem 0;
}

.area-metric-label {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #6b7280;
}

.area-metric-value {
  font-size: 0.95rem;
  font-weight: 700;
  color: #1e3329;
  font-variant-numeric: tabular-nums;
}

.area-metric-value--muted {
  color: #9ca3af;
  font-weight: 500;
  font-style: italic;
  font-size: 0.8rem;
}

/* ─── Winner highlight (2-area mode only) ────────────────────────── */

.area-metric--winner {
  background: rgba(61, 139, 95, 0.06);
  border-radius: 0.25rem;
  margin: 0 -0.35rem;
  padding: 0.3rem 0.35rem;
}

.area-metric--winner .area-metric-value {
  color: #3d8b5f;
}

/* ─── Section titles ──────────────────────────────────────────────── */

.area-section-title {
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #9ca3af;
  margin: 0.75rem 0 0.35rem;
}

.area-section-title:first-child {
  margin-top: 0;
}

.area-compare-footnote {
  margin: 0.4rem 0 0.65rem;
  font-size: 0.65rem;
  color: #6b7280;
  font-style: italic;
}

/* ─── Chart containers ────────────────────────────────────────────── */

.area-chart {
  position: relative;
  height: 160px;
  box-sizing: border-box;
  padding: 1rem;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 1rem;
  box-shadow: 0 10px 24px rgba(30, 51, 41, 0.05);
}

.area-chart--tall {
  height: 200px;
}

/* ─── Comparison table (desktop) ──────────────────────────────────── */

.area-compare-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 1.5rem;
  font-size: 0.8125rem;
}

.area-compare-table th {
  text-align: left;
  padding: 0.5rem 0.75rem;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: #9ca3af;
  border-bottom: 2px solid #e5e7eb;
}

.area-compare-table th:not(:first-child),
.area-compare-table td:not(:first-child) {
  text-align: right;
}

.area-compare-table td {
  padding: 0.5rem 0.75rem;
  border-bottom: 1px solid #f3f4f6;
  font-variant-numeric: tabular-nums;
}

.area-compare-table td:first-child {
  font-weight: 600;
  color: #6b7280;
}

.area-compare-table tr:last-child td {
  border-bottom: none;
}

.area-compare-table .td--winner {
  color: #3d8b5f;
  font-weight: 700;
}

/* ─── Mobile tabs ─────────────────────────────────────────────────── */

.area-tabs {
  display: none;
}

.area-tab {
  padding: 0.5rem 1rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: #6b7280;
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  transition: color 0.15s ease, border-color 0.15s ease;
}

.area-tab:hover {
  color: #1e3329;
}

.area-tab--active {
  color: #008080;
  border-bottom-color: #008080;
}

/* ─── Overlay price chart (combined) ─────────────────────────────── */

.area-overlay-chart {
  position: relative;
  height: 220px;
  margin-top: 1.5rem;
  box-sizing: border-box;
  padding: 1rem;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 1rem;
  box-shadow: 0 10px 24px rgba(30, 51, 41, 0.05);
}

.area-compare-table-card {
  margin-top: 1.5rem;
  padding: 0.5rem 0;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 1rem;
  box-shadow: 0 10px 24px rgba(30, 51, 41, 0.05);
  overflow-x: auto;
}

.area-compare-table-card .area-compare-table {
  margin-top: 0;
}

/* ─── Responsive: mobile ──────────────────────────────────────────── */

@media (max-width: 767px) {
  .area-compare-grid {
    grid-template-columns: 1fr !important;
  }

  .area-compare-grid .area-compare-card {
    display: none;
  }

  .area-compare-grid .area-compare-card--active {
    display: block;
  }

  .area-compare-sidecard--map {
    grid-column: auto;
  }

  .area-tabs {
    display: flex;
    gap: 0;
    border-bottom: 1px solid #e5e7eb;
    margin-bottom: 1rem;
    overflow-x: auto;
  }

  .area-compare-table {
    font-size: 0.75rem;
  }

  .area-compare-table th,
  .area-compare-table td {
    padding: 0.4rem 0.5rem;
  }

  .area-overlay-chart {
    height: 180px;
  }

  .area-compare-mini-map {
    height: 14rem;
  }
}

/* ─── Dark mode ───────────────────────────────────────────────────── */

.dark .area-picker-input {
  color: var(--color-teal-dark);
  background: var(--color-surface-alt);
  border-color: var(--color-border);
}

.dark .area-picker-input:focus {
  border-color: #2dd4bf;
  box-shadow: 0 0 0 3px rgba(45, 212, 191, 0.15);
}

.dark .area-picker-results {
  background: var(--color-surface);
  border-color: var(--color-border);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
}

.dark .area-picker-item:hover,
.dark .area-picker-item--focused {
  background: var(--color-surface-alt);
}

.dark .area-chip {
  color: var(--color-teal-dark);
  background: var(--color-surface-alt);
  border-color: var(--color-border);
}

.dark .area-compare-card {
  background: var(--color-surface);
  border-color: var(--color-border);
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.2);
}

.dark .area-compare-card-header {
  border-bottom-color: var(--color-border-light);
}

.dark .area-compare-hero {
  background: var(--color-surface-alt);
}

.dark .area-compare-sidecard {
  background: var(--color-surface);
  border-color: var(--color-border);
  box-shadow: 0 18px 34px rgba(0, 0, 0, 0.2);
}

.dark .area-compare-sidecard-header {
  border-bottom-color: var(--color-border-light);
}

.dark .area-compare-sidecard-title {
  color: var(--color-teal-dark);
}

.dark .area-compare-sidecard-subtitle {
  color: var(--color-text-faint);
}

.dark .area-compare-mini-map {
  background: #111827;
}

.dark .area-compare-mini-map--empty {
  background: #111827;
}

.dark .area-compare-mini-map-empty-text {
  color: #94a3b8;
}

.dark .area-compare-card-title {
  color: var(--color-teal-dark);
}

.dark .area-compare-card-district {
  color: var(--color-text-faint);
}

.dark .area-compare-card-district a:hover {
  color: #2dd4bf;
}

.dark .area-metric-label {
  color: var(--color-text-muted);
}

.dark .area-metric-value {
  color: var(--color-teal-dark);
}

.dark .area-metric-value--muted {
  color: var(--color-text-faint);
}

.dark .area-metric--winner {
  background: rgba(45, 212, 191, 0.08);
}

.dark .area-section-title {
  color: var(--color-text-faint);
}

.dark .area-chart,
.dark .area-overlay-chart,
.dark .area-compare-table-card {
  background: var(--color-surface);
  border-color: var(--color-border);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.22);
}

.dark .area-compare-table th {
  color: var(--color-text-faint);
  border-bottom-color: var(--color-border);
}

.dark .area-compare-table td {
  border-bottom-color: var(--color-border-light);
}

.dark .area-compare-table td:first-child {
  color: var(--color-text-muted);
}

.dark .area-tab {
  color: var(--color-text-muted);
}

.dark .area-tab:hover {
  color: var(--color-teal-dark);
}

.dark .area-tab--active {
  color: #2dd4bf;
  border-bottom-color: #2dd4bf;
}

.dark .area-tabs {
  border-bottom-color: var(--color-border);
}

@keyframes area-compare-hero-camera {
  0% {
    transform: scale(1.06) translate3d(0, 0, 0);
    filter: blur(0px);
  }
  18% {
    transform: scale(1.09) translate3d(-0.6%, 0.4%, 0);
    filter: blur(0px);
  }
  22% {
    filter: blur(0.8px);
  }
  28% {
    transform: scale(1.12) translate3d(-1.2%, 0.8%, 0);
    filter: blur(0px);
  }
  55% {
    transform: scale(1.1) translate3d(0.8%, -0.6%, 0);
    filter: blur(0px);
  }
  72% {
    transform: scale(1.08) translate3d(0.2%, -0.2%, 0);
    filter: blur(0px);
  }
  76% {
    filter: blur(0.55px);
  }
  100% {
    transform: scale(1.06) translate3d(0, 0, 0);
    filter: blur(0px);
  }
}
