/* ── Hero ─────────────────────────────────────────── */
.app-hero {
  border-bottom: 1px solid var(--color-border);
  padding: 1.25rem 1.5rem 1.1rem;
}
.app-hero--matcha {
  background: var(--c-matcha-bg);
  border-bottom-color: var(--c-matcha-border);
}
.app-hero__inner { margin: 0 auto; }
.app-hero__title {
  font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 800;
  color: var(--c-matcha-text); letter-spacing: -.02em;
  margin: 0 0 .5rem; line-height: 1.2;
}
.app-hero__desc {
  font-size: .9rem; color: var(--color-text-secondary);
  max-width: 660px; line-height: 1.6; margin: 0 0 .85rem;
}
.app-hero__chips { display: flex; flex-wrap: wrap; gap: .35rem; }
.hero-chip {
  display: inline-flex; align-items: center;
  padding: .22rem .65rem; font-size: .72rem; font-weight: 700;
  background: var(--color-surface); border: 1.5px solid var(--c-matcha-border);
  border-radius: var(--radius-full); color: var(--c-matcha-text); white-space: nowrap;
}

/* ── Tool shell ─────────────────────────────────────────── */
.tool-wrap {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  margin-bottom: var(--space-10);
}

/* ── Drop zone ──────────────────────────────────────────── */
.drop-zone {
  padding: 3.5rem var(--space-8);
  background: var(--c-matcha-bg);
  border: 2.5px dashed var(--c-matcha-border);
  border-radius: var(--radius-xl);
  text-align: center;
  cursor: pointer;
  transition: background .15s, border-color .15s;
  outline: none;
}
.drop-zone:focus-visible { box-shadow: 0 0 0 3px rgb(56 90 32 / 0.2); }
.drop-zone.drag-over { background: #cde8b4; border-color: #7db860; }
.dz-icon  { font-size: 2.5rem; display: block; margin-bottom: var(--space-3); transition: transform .2s; }
.drop-zone.drag-over .dz-icon { transform: translateY(-4px); }
.dz-title { font-size: var(--text-lg); font-weight: var(--weight-semibold); color: var(--c-matcha-text); margin: 0 0 var(--space-2); }
.dz-sub   { font-size: var(--text-sm); color: var(--color-text-muted); margin: 0 0 var(--space-3); }
.dz-browse { background: none; border: none; color: var(--color-accent); font: inherit; cursor: pointer; padding: 0; text-decoration: underline; }
.dz-limit  { font-size: var(--text-xs); color: var(--color-text-muted); margin: 0; }
#file-input { display: none; }

/* ── Work area ──────────────────────────────────────────── */
#work-area { padding: var(--space-6); }

/* ── File bar ───────────────────────────────────────────── */
.file-bar {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-3); margin-bottom: var(--space-5);
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface-alt); border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.file-bar__name { font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--color-text-primary); }
.file-bar__size { font-size: var(--text-xs); color: var(--color-text-muted); }
.btn-link { background: none; border: none; cursor: pointer; padding: 0; font: inherit; font-size: var(--text-sm); color: var(--color-text-muted); }
.btn-link:hover { color: var(--color-text-primary); }

/* ── Stats row ──────────────────────────────────────────── */
.stats-row { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-bottom: var(--space-5); }
.stat-chip {
  flex: 1; min-width: 7rem;
  background: var(--c-matcha-bg);
  border: 1px solid var(--c-matcha-border);
  border-radius: var(--radius-lg);
  padding: var(--space-3) var(--space-4);
  text-align: center;
}
.stat-chip strong { display: block; font-size: var(--text-lg); font-weight: var(--weight-bold); color: var(--c-matcha-text); }
.stat-chip span   { font-size: var(--text-xs); color: var(--color-text-muted); }

.divider { height: 1px; background: var(--color-border); margin: var(--space-5) 0; }

/* ── Options row ────────────────────────────────────────── */
.opt-row { display: flex; gap: var(--space-6); flex-wrap: wrap; margin-bottom: var(--space-5); align-items: flex-start; }
.opt-group { display: flex; flex-direction: column; gap: var(--space-2); }
.opt-lbl { font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--color-text-secondary); display: block; }

.seg { display: flex; gap: var(--space-2); }
.seg label { flex: 1; }
.seg input[type="radio"] { display: none; }
.seg-btn { display: block; text-align: center; padding: var(--space-2) var(--space-3); font-size: var(--text-sm); border: 1px solid var(--color-border); border-radius: var(--radius-md); cursor: pointer; color: var(--color-text-secondary); transition: all .1s; user-select: none; white-space: nowrap; }
.seg input[type="radio"]:checked + .seg-btn { background: var(--c-matcha-bg); border-color: var(--c-matcha-border); color: var(--c-matcha-text); font-weight: var(--weight-semibold); }

.precision-wrap { display: flex; align-items: center; gap: var(--space-3); }
.precision-wrap input[type="range"] { width: 8rem; accent-color: var(--c-matcha-text); cursor: pointer; }
.precision-val { font-size: var(--text-sm); font-weight: var(--weight-semibold); color: var(--c-matcha-text); min-width: 1.4rem; text-align: center; }

.toggle-wrap { display: flex; align-items: center; gap: var(--space-2); cursor: pointer; }
.toggle-wrap input[type="checkbox"] { accent-color: var(--c-matcha-text); width: 1rem; height: 1rem; cursor: pointer; }
.toggle-lbl { font-size: var(--text-sm); color: var(--color-text-secondary); }

/* ── Split panel ────────────────────────────────────────── */
.split-panel {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
  height: 22rem;
}
@media (max-width: 600px) {
  .split-panel { grid-template-columns: 1fr; height: auto; }
  .map-panel { height: 16rem; }
}

/* ── JSON code panel ────────────────────────────────────── */
.code-panel {
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: auto;
  position: relative;
  display: flex;
  flex-direction: column;
}
.code-panel pre {
  margin: 0;
  padding: var(--space-4);
  font-family: ui-monospace, 'SFMono-Regular', Consolas, monospace;
  font-size: 0.70rem;
  line-height: 1.55;
  color: var(--color-text-secondary);
  white-space: pre;
  tab-size: 2;
  flex: 1;
  overflow: auto;
}
.code-panel .tok-key  { color: var(--c-matcha-text); font-weight: var(--weight-semibold); }
.code-panel .tok-str  { color: #b45309; }
.code-panel .tok-num  { color: #1565c0; }
.code-panel .tok-kw   { color: #7c3aed; }
.code-panel .tok-punc { color: var(--color-text-muted); }
.truncation-note {
  background: var(--c-matcha-bg);
  border-top: 1px solid var(--c-matcha-border);
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-xs);
  color: var(--c-matcha-text);
  text-align: center;
  flex-shrink: 0;
}

/* ── Map panel ──────────────────────────────────────────── */
.map-panel {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  position: relative;
}
#leaflet-map { width: 100%; height: 100%; min-height: 10rem; }
.map-empty {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: var(--space-2);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  pointer-events: none;
  background: var(--color-surface-alt);
}

/* ── Feature legend ─────────────────────────────────────── */
.legend-row { display: flex; gap: var(--space-4); flex-wrap: wrap; margin-bottom: var(--space-5); min-height: 1.25rem; }
.legend-item { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-xs); color: var(--color-text-secondary); }
.legend-dot  { width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0; }
.legend-line { width: 18px; height: 3px; border-radius: 2px; flex-shrink: 0; }
.legend-poly { width: 12px; height: 12px; border-radius: 2px; flex-shrink: 0; }

/* ── Feature filters ────────────────────────────────────── */
.filter-check {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  cursor: pointer;
  padding: var(--space-1) var(--space-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  transition: background .1s, border-color .1s;
}
.filter-check:hover { background: var(--c-matcha-bg); border-color: var(--c-matcha-border); }
.filter-check input[type="checkbox"] { accent-color: var(--c-matcha-text); width: 0.9rem; height: 0.9rem; cursor: pointer; }

/* ── Actions ────────────────────────────────────────────── */
.action-wrap { display: flex; gap: var(--space-3); flex-wrap: wrap; align-items: center; }
.btn-icon { display: inline-flex; align-items: center; gap: var(--space-2); }
.copy-feedback { font-size: var(--text-sm); color: var(--c-matcha-text); font-weight: var(--weight-medium); opacity: 0; transition: opacity .3s; pointer-events: none; }
.copy-feedback.show { opacity: 1; }

.learn-more{max-width:820px;margin:1.25rem auto 0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:1.1rem 1.5rem}
.learn-more-title{font-size:1.1rem;font-weight:800;color:var(--fl-text);margin:0 0 .75rem}
.learn-more h3{font-size:1rem;font-weight:800;color:var(--color-text-primary);margin:1.1rem 0 .5rem}
.learn-more p{font-size:.88rem;line-height:1.65;color:var(--color-text-secondary);margin:0 0 .75rem}
.learn-more a{color:var(--fl-text)}
.learn-more .faq-item{margin-bottom:.75rem}
.learn-more .faq-q{font-size:.88rem;font-weight:700;color:var(--color-text-primary);margin:0 0 .25rem}
.learn-more-meta{font-size:.72rem;color:var(--color-text-muted);margin-top:1rem}
