/* ── 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); }
.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); }

/* ── 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); }

/* ── File info 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); }

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

/* ── Options ────────────────────────────────────────────── */
.opt-lbl { font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--color-text-secondary); margin-bottom: var(--space-2); display: block; }
.opt-hint { font-size: var(--text-xs); color: var(--color-text-muted); margin-top: var(--space-1); }

/* data type radio */
.seg { display: flex; gap: var(--space-2); margin-bottom: var(--space-5); }
.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; }
.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); }
.seg input[type="radio"]:disabled + .seg-btn { opacity: 0.35; cursor: not-allowed; }

/* column checkboxes */
.col-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(11rem, 1fr)); gap: var(--space-2); margin-top: var(--space-3); }
.col-check { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); color: var(--color-text-secondary); cursor: pointer; border-radius: var(--radius-md); padding: var(--space-1); transition: background .1s; }
.col-check:hover { background: var(--c-matcha-bg); }
.col-check.dragging { opacity: 0.4; }
.col-check.drag-over-item { background: var(--c-matcha-bg); outline: 2px dashed var(--c-matcha-border); }
.col-check input[type="checkbox"] { accent-color: var(--c-matcha-text); width: 1rem; height: 1rem; flex-shrink: 0; cursor: pointer; }
.col-tag { font-size: var(--text-xs); background: var(--c-matcha-bg); color: var(--c-matcha-text); border-radius: var(--radius-sm); padding: 0.1rem var(--space-1); margin-left: auto; }
.drag-handle { font-size: var(--text-xs); color: var(--color-text-muted); cursor: grab; flex-shrink: 0; line-height: 1; }

/* ── Preview table ──────────────────────────────────────── */
.preview-wrap {
  margin-top: var(--space-5);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: auto;
  max-height: 16rem;
}
.preview-table { width: 100%; border-collapse: collapse; font-size: var(--text-xs); }
.preview-table th {
  position: sticky; top: 0;
  background: var(--c-matcha-bg);
  color: var(--c-matcha-text);
  font-weight: var(--weight-semibold);
  padding: var(--space-2) var(--space-3);
  text-align: left; white-space: nowrap;
  border-bottom: 1px solid var(--c-matcha-border);
}
.preview-table td { padding: var(--space-1) var(--space-3); color: var(--color-text-secondary); white-space: nowrap; border-bottom: 1px solid var(--color-border); }
.preview-table tr:last-child td { border-bottom: none; }
.preview-note { font-size: var(--text-xs); color: var(--color-text-muted); margin-top: var(--space-2); text-align: right; }

/* ── Action ─────────────────────────────────────────────── */
.action-wrap { margin-top: var(--space-6); display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; }
.action-wrap .btn { flex-shrink: 0; }
.no-data-msg { font-size: var(--text-sm); color: var(--color-text-muted); padding: var(--space-4); text-align: center; }

.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(--c-matcha-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(--c-matcha-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}
